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内 容 人 简介 


《硝烟 中 的 Scrum 和 XP 一 一 我 们 如 何 实施 Scrum》 源 自 真实 的 故 

事 ，Henrik  Kniberg 以 过 来 人 的 号 份 ， 回 顾 了 他 在 一 年 时 间 内 珊 领 40 人 
团队 实施 敏捷 转型 和 持续 过 程 改进 的 杀 喘 经 历 。 在 Henrik 的 领导 下 ， 
队 经 历 了 不 同 的 规模 ， 不 同 的 sprint 长 度 ， 不 同 的 定义 “done” 的 方式 ， 不 
同 格式 的 产品 backlog 和 sprint backlog， 不 同 的 测试 策略 ， 不 同 的 演示 方 
式 ， 同 步 多 个 Scrum 团 队 工 作 的 不 同方 式 ， 如 此 等 等 。 他 们 还 尝试 了 XP 
实践 一 一 体验 不 同方 式 的 持续 构建 、 结 对 编程 、 测 试 驱动 开发 等 ， 阐 述 
了 如 何 结合 使 用 XP 与 Scrum。 





本 书 的 特色 在 于 实践 ， 对 正在 实施 Scrum 敏 捷 软 件 开发 的 读者 具有 
一 定 的 参考 价值 和 指导 作用 。 
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Fri Jeff Sutherland 





开发 团队 需要 了 解 一 些 Scrum 的 基础 知识 。 该 怎样 创建 产品 
backlog， 对 它 进行 估算 ? 怎样 把 它 转 化 成 sprint backlog? 怎样 管理 燃 尽 
图 (burndown chart) ， 计 算 团 队 的 生产 率 (velocity)〉 ? Henrik 的 书 可 
以 用 作 一 些 基础 实践 的 入 门 指南 ， 帮 助 团队 从 试用 Scrum 中 成 长 ， 最 终 
成 功 地 实施 Scrum。 








当前 ， 恨 好 的 Scrum 执 行 过 程 对 需要 风险 投资 的 团队 正 变 得 日 益 重 
要 。 我 现在 是 一 个 风险 投资 团队 的 敏捷 教练 ， 为 了 帮助 他 们 达成 目标 ， 
我 给 出 的 建议 是 : 只 给 敏捷 实践 实施 情况 民 好 的 敏捷 公司 投资 。 团 队 中 
的 资深 合伙 人 (senior partner) 在 问 所 有 的 待 投资 企业 问 同 一 个 问题 : 
你 们 是 否 清楚 团队 的 生产 率 ? 目前 他 们 都 很 难 做 出 明确 的 答复 。 要 想 在 
将 来 得 到 投资 ， 开 发 团队 就 必须 清楚 自己 的 软件 生产 率 。 


为 什么 这 一 点 如 此 重要 呢 ? 如 果 团 队 不 清楚 自己 的 生产 率 ， 那 么 产 
品 负责 人 (product owner) 就 无 法 用 可 靠 的 发 布 日 期 来 创建 产品 路 线 
图 。 如 果 没 有 可 靠 的 发 布 日 期 ， 公 司 的 产品 就 可 能 会 失败 ， 投 资 人 的 钱 
WA TEUNGA! 





无 论 公 司 规模 大 小 ， 创 办 时 间 长 短 ， 或 者 是 否 有 资金 注入 ， 这 个 问 
题 都 是 它们 所 要 面 对 的 。 在 最 近 在 伦敦 举办 的 一 个 大 会 上 ， 我 们 曾 讨论 
过 Google 内 部 的 Scrum 实 施 状 况 ， 当 时 的 听众 有 135 个 人 ， 我 问 他 们 中 有 
多 少 人 在 使 用 Scrum， 只 有 30 个 举 手 。 我 义 接 着 问 他 们 是 否 在 根据 Nokia 
标准 来 做 迭代 开发 。 迭 代 开 发 是 敏捷 宣言 的 基本 原则 一 一 在 早期 频繁 地 








交付 可 工作 的 软件 。Nokia 用 了 几 年 时 间 ， 对 上 百 个 Scrum 团 队 的 工作 进 
行 了 回顾 ， 总 结 出 迭代 开发 的 基本 需求 : 





四 ”迭代 要 有 固定 时 长 《被 称 为 “时 间 盒 ”， 即 timebox) ， 不 能 超过 
六 个 星期 ; 

”在 每 一 次 达 代 的 结尾 ， 代 码 都 必须 经 过 QA 的 测试 ， 能 够 正常 工 
作 。 


使 用 Scrum 的 30 个 人 里 面 ， 只 有 一 半 人 说 他 们 遵守 了 Nokia 标 准 ， 符 
合 敏 捷 宣 言 的 首要 原则 。 我 又 问 他 们 是 否 遵 守 了 Nokia 的 Scrum 标 准 : 








m Scrum 团 队 必 须要 有 产品 负责 人 ， 而 且 团 队 都 清楚 这 个 人 是 
谁 ; 


四 ”产品 负责 人 必须 要 有 产品 backlog， 其 中 包括 团队 对 它 进行 的 估 





e 团队 必须 要 有 燃 尽 图 ， 而 且 要 了 解 他 们 目 己 的 生产 率 ; 
”在 一 个 sprint 中 ， 外 人 不 能 干涉 团队 的 工作 。 


仅 有 的 30 个 实践 Scrum 的 在 场 人 士 中 ， 只 有 3 个 能 够 通过 Nokia 的 
Scrum 测 试 。 看 来 只 有 这 几 个 团队 才 有 可 能 在 将 来 得 到 我 的 风险 投资 伙 
伴 的 钱 了 。 


如 有 果 按 照 Henrik 列 出 的 实践 执行 ， 那 么 你 就 会 拥有 如 下 产物 :产品 
backlog、 对 于 这 个 backlog 的 估算 、 燃 尽 图 ， 你 会 了 解 团队 的 生产 率 ， 
并 掌握 在 切实 有 效 的 Scrum 过 程 中 所 包含 的 众多 基础 实践 。 这 些 收获 就 
是 本 书 的 价值 所 在 。 你 将 会 通过 Nokia 的 Scrum 测 试 ， 对 工作 的 投资 也 会 





物 有 所 值 。 如 果 你 的 公司 还 正 处 于 创业 阶段 ， 也 许 还 会 收 到 风险 投资 


队 的 资金 注入 。 你 也 许 会 塑造 软件 开发 的 未 来 ， 成 为 下 一 代 软 件 产品 
领 革 产品 的 创建 者 。 


Jeff Sutherland, Ph.D 


Scrum 共 同 创始 人 


F£ 2———_Mike Cohn 


Scrum 和 极限 编程 CXP) MERANER IE CAN 28 Fe oc a — 
FY AZTI L ERR. AREER, ATTRIB Hi]. CRE ASE TE 
短 时 间 内 交付 可 工作 的 代码 ， 这 就 意味 着 Scrum 和 XP 团队 没有 时 间 进 行 
理论 研究 。 他 们 不 会 花 时 间 用 建 模 工具 来 画 UML 图 、 编 写 完美 的 需求 
文档 ， 也 不 会 为 了 应 对 在 可 预计 的 未 来 中 所 有 可 能 发 生 的 变化 而 去 写 代 
人 码 。 实 际 上 ，Scrum 和 XP 都 关注 如 何 把 事情 做 好 。 这 些 团 队 承 认 在 开发 
过 程 中 会 犯错 ， 但 是 他 们 明白 : 要 投入 实践 中 ， 动 手 去 构建 产品 ， 这 才 
是 找 出 错误 的 最 好 方式 ; 不 要 只 是 停留 在 理论 层次 上 对 软件 进行 分 机 和 
wit 


注重 实践 而 非 理 论 研 究 ， 这 正 是 本 书 的 独到 之 处 。Henrik Kniberg 
很 清楚 ， 初 水门 径 的 人 更 需要 这 种 书籍 。 他 没有 对 “什么 是 Scrum” 进 行 
抑 长 的 摘 述 ， 只 是 给 出 了 一 些 网 站 作为 参考 。 从 一 开始 他 就 在 讲 他 的 团 
队 如 何 管理 产品 backlog， 并 基于 它 进 行 工 作 。 接 着 他 又 讲述 了 成 功 的 敏 
捷 项 目 中 包含 的 所 有 元 素 和 实践 。 没 有 理论 ， 没 有 引用 ， 没 有 脚注 ， 没 
有 废话 。Henrik 的 书 没有 从 哲学 角度 上 分 析 为 什么 Scrum 可 以 工作 ， 没 
有 分 析 为 什么 你 可 能 会 尝试 不 同 的 选择 。 它 描述 的 是 一 个 成 功 敏 捷 团 队 
的 工作 过 程 s 





所 以 本 书 的 副标题 “我 们 如 何 实施 Scrum”  ” 才 显 得 格外 贴 
切 。 这 也 许 不 是 你 ”实施 Scrum 的 方式 ， 这 是 Henrik 的 团队 实施 Scrum 的 
方式 。 你 也 许 会 问 :“ 为 什么 我 需要 关心 别 的 团队 怎样 实施 Scrum? ”这 


是 因为 通过 关注 其 他 团队 的 实施 过 程 ， 尤 其 是 成 功 的 案例 ， 我 们 就 可 以 
学 到 更 好 的 实施 方式 。 这 不 是 ， 也 永远 不 会 是 “Scrum 最 佳 实践 ”的 罗 
列 ， 因 为 团队 和 项 目的 真实 场景 要 比 其 他 一 切 都 重要 得 多 。 我 们 应 该 了 
解 的 是 优秀 实践 及 其 应 用 范围 ， 而 不 是 最 佳 实践 。 在 读 过 足够 多 的 成 功 
团队 的 实践 经 验 以 后 ， 你 便 会 做 好 充分 的 准备 ， 来 面 对 实 施 Scrum 和 XP 
的 过 程 中 将 会 遇 到 的 艰难 险阻 。 














Henrik 提 供 了 很 多 优秀 实践 ， 还 有 对 应 的 使 用 场景 ， 通 过 它们 ， 我 
们 能 够 更 好 地 和 擎 握 如 何在 目 己 的 项 目 中 ， 在 战壕 里 使 用 Scrum 和 XP。 


Mike Cohn 


《用 户 故 事 与 敏 捷 方 法 》 与 《Scrum 和 人 敏捷 软件 开发 》 作 者 


译 者 序 


孙子 兵法 有 云 : 兵 无 第 势 ， 水 无 党 形 ， 能 因 敌 变化 而 取胜 者 谓 之 
神 。 很 多 人 都 癌 往 用 兵 如 神 的 境界 ， 想 必 也 知道 读 万 卷 书 不 如 行 万 里 
路 ， 纸 上 谈 兵 的 故事 更 是 耳 熬 能 详 ， 但 侦 仿 不 能 举一反三 。 


且 看 风 清 扬 的 一 段 话 : “.…… 你 将 这 华山 派 的 三 四 十 招 融会 贯通 ， 
设想 如 何 一 气 呵 成 ， 然 后 全 部 将 它 豆 了 ， 态 得 干 干 滔 浪 ， 一 招 也 不 可 留 
在 心中 。 待 会 便 以 什么 招数 也 没有 的 华山 剑 法 ， 去 跟 田 伯 光 对 打 。” 如 
果 有 人 说 ， 既 然 “ 无 招 胜 有 招 ” 是 武 学 的 最 局 境界 ， 那 干脆 什么 招数 都 不 
要 学 ， 拿 把 剑 乱 挥 乱舞 ， 处 处 破绽 ， 也 就 处 处 无 破绽 ， 便 是 天 下 第 一 
了 了。 了 听 到 这 话 的 人 肯定 会 笑 他 太 缺 心眼 。 





我 在 这 里 不 想 解 释 为 什么 上 面 那 种 说 法 缺 心眼 ， 因 为 只 要 不 是 缺 心 
眼 的 读者 就 肯定 能 够 理解 说 他 缺 心眼 的 理由 。 但 有 名 话 叫 “ 不 识 庐山 真 
面目 ， 只 缘 身 在 此 山中 ”。 对 竺 离 目 身 疝 远 的 事物 时 ， 人 们 可 以 把 它 分 
析 得 淋漓 尽 致 ， 但 到 了 自己 映 上 ， 束 往往 成 了 当局 者 迷 ， 劳 观 者 清 。 壁 
如 至 春 ， 艾 如 爱情 ， 璧 如 敏捷 软件 开发 。 

















我 想 ， 这 本 书 的 读者 大 概 都 知道 ， 现 如 今 敏捷 开发 是 何等 炙 手 可 
热 ， 但 潮流 一 起 ， 跟 风 者 势必 有 之 。 虽 然 没 法 在 这 篇 短 短 的 序 中 逐一 批 
驶 ， 大 家 也 可 以 仔细 思索 一 下 ， 在 周边 是 否 存 在 缺 心眼 的 做 法 。 比 如 ， 
把 bad smells 背 下 来 以 后 就 大 谈 重 构 的 好 处 ， 版 本 控制 、 缺 陷 跟 踪 、 配 
置 管 理 等 一 无 所 有 ， 便 一 味 退 求 持续 集成 ， 单 元 测试 还 不 会 写 ， 束 疯狂 
宣传 测试 驱动 开发 .…… 这 些 都 还 好 ， 只 要 没有 把 敏捷 等 同 于 欠 代 ， 等 同 











FMM GE, MIR; 这 也 无 所 谓 ， 只 要 没有 在 实际 上 对 敏捷 一 无 所 

知 、 对 想 要 达到 的 目标 不 甚 了 了、 对 项 目 中 存在 的 问题 视 若 无 睹 的 情况 

下 宣传 敏捷 、 推 行 敏捷 就 可 以 了 。 但 如 果 前 面 那些 条 件 都 吻合 ， 最 后 这 
点 还 能 不 满足 么 ? 





其 实 ， 人 敏捷 不 是 说 出 来 的 ， 古 干 出 来 的 。 
为 序 。 


ral 


A) S——2,, ScrumkX J! 


Scrum 成 了 ! 至 少 对 我 们 来 说 它 已 经 成 功 了 (这 里 指 的 是 我 当前 在 
斯 德 哥 尔 摩 的 客户 ， 名 字 略 过 不 提 ) 。 希 望 它 对 你 们 也 一 样 有 用 ! 也 许 
这 本 书 会 对 你 们 实施 Scrum 的 过 程 有 所 助 益 。 





这 是 我 第 一 次 看 到 一 种 开发 方法 论 〈 哦 ， 对 不 起 ，Ken， 它 是 一 种 
框架 ) 可 以 脱离 开 书 本 成 功 运 作 。 它 拿 来 就 能 用 。 所 有 人 一 一 包括 开 
发 人 人员、 测试 人 员 和 经 理 一 一 痢 为 此 而 高 兴 。 它 帮助 我 们 走出 了 艰难 的 
境地 ， 而 且 让 我 们 在 剧烈 的 市 场 动 荡 和 大 规模 的 公司 裁员 中 依然 能 够 集 
中 精力 在 项 目 上 。 


我 不 该 说 我 为 此 感到 惊讶 ， 但 实情 确实 如 此 。 在 一 开始 我 大 致 翻 了 
几 本 讲 Scrum 的 书 ， 它 们 把 Scrum 摘 述 得 挺 不 错 ， 却 给 我 留 下 了 一 种 太 
过 美好 以 致 不 太 真 实 的 感觉 〈 我 们 都 知道 * 某 些 东 西 看 上 去 太 好 
本 这 ”这 类 说 法 的 含义 ) 。 所 以 我 没 法 不 对 它 有 点 怀疑 。 但 在 使 用 
Scrum 一 年 以 后 ， 先 前 的 零星 疑虑 早已 烟消云散 。 我 被 它 深 深 地 震撼 了 
《我 们 团队 中 的 大 部 分 人 都 和 我 一 样 ) ， 以 后 只 要 没有 充分 的 理由 来 阻 
止 我 ， 我 都 会 继续 使 用 Scrum。 











致谢 


本 书 初 稿 完 成 仅 用 了 一 个 周末 ， 但 很 显然 : 那 是 一 个 超 高 强度 工作 
的 周末 ! 投入 程度 高 达 150%: o) 
感谢 我 的 妻子 Sophia 和 两 个 孩子 Dave 与 Jenny， 我 那个 周末 扔 下 她 


们 独 目 工作 ， 她 们 对 此 表示 了 宽容 ， 还 应 该 感谢 Sophia 的 父母 
和 J6rgen， 在 我 忙碌 的 时 候 ， 他 们 过 来 一 起 照看 整个 家 庭 。 





Eva 


同时 ， 还 应 该 感谢 在 斯 德 哥 尔 摩 Crisp 工 作 的 同事 ， 还 有 
scrumdevelopment yahoo 讨论 组 的 成 员 ， 他 们 一 起 校 稿 ， 提 出 了 很 多 改 
进 意见 。 


最 后 ， 我 要 深 深 感 谢 所 有 的 读者 ， 从 你 们 长 期 的 反馈 中 我 收获 颇 
丰 。 尤 其 要 指出 ， 能 够 通过 本 书 点 燃 许 多 人 尝试 敏捷 软件 开 友 的 热情 ， 
这 让 我 感到 特别 开心 ! 


序 1 Jeff Sutherland 





F£ 2———Mike Cohn 
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有 关 Henrik kniberg 


m fani HA 
四” 把 写本 书 的 原因 


m Scrum 到 底 是 什么 


你 即将 在 组 织 中 开始 使 用 Scrum。 或 者 你 已 经 用 过 了 几 个 月 。 你 已 
经 了 解 了 基本 概念 ， 读 过 了 几 本 书 ， 也 许 你 还 已 经 通过 了 ScrumMaster 
Ve Suge 





但 是 你 仍 会 感到 迷 范 。 


用 Ken Schwaber 的 话说 ，Scrum 不 是 方法 学 ， 它 是 一 个 框架 o Ha 
是 说 Scrum 不 会 告诉 你 到 底 该 做 些 什 么 。 靠 ! 


下 面 有 一 个 好 消息 和 一 个 坏 消 息 。 好 消息 是 我 即将 和 你 们 分 享 我 使 
用 Scrum 的 经 验 ， 还 有 种 种 恼人 的 细节 。 而 坏 消 息 是 ， 这 只 是 我 个 人 的 
经 历 。 你 ”不 应 该 完全 仿照 我 的 做 法 。 实 际 上 如 果 换 个 不 同 的 场景 ， 我 
也 许 就 会 换 种 实践 方式 了 。 














Scrum 的 强大 和 令 人 痛 百 之 处 就 在 于 你 不 得 不 根据 自己 的 具体 情况 
来 对 它 进 行 调整 。 


过 去 的 一 年 中 ， 我 在 一 个 大 约 40 人 的 开发 团队 里 面试 验 性 地 使 用 了 
Scrum。 当 时 公司 正 处 于 困境 ， 没 日 没 夜 地 加 班 ， 产 品质 量 低下 ， 很 多 
人 都 忙 着 四 处 救火 ， 交 付 日 期 也 一 再 拖延 。 公 司 已 经 决定 了 使 用 
Scrum， 但 是 并 没有 完全 洲 实 ， 剩 下 的 部 分 就 是 我 的 工作 了 。 在 那个 时 
候 ， 对 团队 中 的 大 多 数 人 来 说 ,“Scrum>” 就 只 是 一 个 陌生 的 、 时 时 能 够 
MERENAH EC; 仅 此 而 已 ， 和 他 们 日 党 的 工作 没有 丝毫 
的 天 系 。 














一 年 过 去 了 ， 我 们 在 公司 里 从 上 到 下 都 实现 了 Scrum。 我 们 试 过 多 
种 团队 规模 〈3 一 12 人 ) 、sprint 长 度 〈2 一 6 个 星期 ) ; 定义 “完成 ”的 不 
同方 式 ; 不 同形 式 的 产品 backlog 和 sprint backlog (Excel、Jira、 索 引 


“BD 3 多 种 测试 策略 、 演示 方式 、 多 个 Scrum 团 队 的 信息 同步 方式 二 可 二 二 志和 
我 们 还 试验 了 XP 实践 一 一 各 种 各 样 的 每 日 构建 ， 结 对 编程 ， 测 试 驱 动 
开发 ， 等 等 ， 还 试 过 把 XP 和 Scrum 进 行 结合 。 


这 是 一 个 持续 学 习 的 过 程 ， 所 以 故事 尚未 结束 。 我 相信 ， 如 果 公 司 
能 够 保持 做 sprint 回 顾 的 恨 好 习惯 ， 他 们 就 会 不 断 得 到 新 的 收获 ， 重 新 
领悟 到 怎样 在 他 们 特有 的 场景 中 ， 恰 如 其 分 地 应 用 Scrum。 


免责 声明 


这 篇 文档 讲述 的 不 是 “正确 ”实现 Scrum 的 方式 ! 它 只 是 表明 了 一 种 
方式 ， 是 我 们 在 一 年 内 不 断 修 正 调整 后 的 结果 。 你 也 可 以 认为 我 们 的 做 
法 是 完全 错误 的 。 








本 文中 所 说 的 一 切 都 是 我 个 人 的 观点 ， 不 代表 Crisp 或 者 我 当前 客户 
的 任何 意见 。 因 此 我 将 避免 提 到 任何 特定 的 产品 或 者 人 名 。 





类 写本 书 的 原因 


在 学 习 Scrum 的 过 程 中 ， 我 读 过 Scrum 和 敏捷 方面 的 书 ， 浏 览 了 许 
多 有 关 Scrum 的 网 站 和 论坛 ， 通 过 了 Ken Schwaber 的 认证 ， 用 各 种 问题 
刁难 他 ， 还 花 了 大 量 的 时 间 跟 同事 进行 讨论 。 但 在 纷乱 苑 杂 的 信息 中 ， 
我 感到 最 有 价值 的 束 是 那些 答 枪 实弹 的 故事 。 它 们 把 “原则 与 实践 ” 变 成 
Tee 咖 ..…….…“ 如 何 真正 动手 去 做 的 过 程 >， 同 时 还 帮 我 意识 到 《〈 有 时 候 
会 帮 我 避免 ) Scrum 新 丁 容易 犯 的 典型 错误 。 














所 以 ， 现 在 轮 到 我 做 出 一 些 回 报 了 。 下 面 就 是 我 以 Scrum 为 枪 的 战 
斗 经 历 。 


希望 本 书 对 有 同样 经 历 的 读者 起 到 抛砖引玉 的 作用 ， 给 我 反馈 ， 疝 
我 开炮 ! 


Scrum 到 底 是 什么 


哦 ， 对 不 起 ， 你 完全 不 了 解 Scrum 或 者 XP? 那 你 最 好 先 去 看 一 下 这 
几 个 链接 : 





= http://agilemanifesto.org/ 
= http://www.mountaingoatsoftware.com/scrum 


= http://www.xprogramming.com/xpmag/whatisxp.htm 


要 是 你 真 没 耐心 去 访问 这 些 网 站 ， 也 没关系 。 随 便 翻 翻 看 看 吧 。 大 
多 数 Scrum 的 相关 术语 都 会 在 书 中 慢 慢 讲 到 ， 你 会 感 兴趣 的 。 


第 2 草 ”我 们 怎样 编写 产品 backlog 


m AMETE 


四 ”我 们 如 何 让 产品 backlog 停 留 在 业务 层次 上 


产品 backlog 是 Scrum 的 核心 ， 也 是 一 切 的 起 源 。 从 根本 上 说 ， 它 整 
是 一 个 需求 或 故事 或 特性 等 组 成 的 列表 ， 按 照 重 要 性 的 级 别 进行 了 排 
序 。 它 里 面包 含 的 是 客户 想 要 的 东西 ， 并 用 客户 的 术语 加 以 摘 述 


我 们 叫 它 故 事 (story) ， 有 时 候 也 叫做 backlog 条 目 《 事 项 ) 。 
我 们 的 故事 包括 这 样 一 些 字段 。 


mE ID 统一 标识 符 ， 就 是 个 目 增 长 的 数字 而 已 。 以 防 重 命名 故事 
以 后 找 不 到 它们 


m Name (名 称 ) 简短 的 、 描 述 性 的 故事 名 。 比 如 “但 看 你 自己 
的 交易 明细 ”。 它 必须 要 含义 明确 ， 这 样 开发 人 员 和 产品 负责 
人 才能 大 致 明白 我 们 说 的 是 什么 东西 ， 跟 其 他 故事 区 分 开 。 它 
一 般 由 2 到 10 个 字 组 成 。 


四 ”Importance 《重要 性 ) ”产品 负责 人 评 出 一 个 数值 ， 指 示 这 个 
故事 有 多 重要 。 例 如 10 或 150。 分 数 越 高 越 重要 。 


口 我 一 直 都 想 避 人 免 “ 优 先 级 ”这 个 说 法 ， 因 为 一 般 说 来 优先 级 1 
都 表示 “最 高 ”优先 级 ， 如 果 后 来 有 其 他 更 重要 的 东西 束 抵 
烦 了 。 它 的 优先 级 评级 应 该 是 什么 呢 ? 优先 级 0? 优先 
级 -1? 





m Initial estimate (初始 估算 ) 团队 的 初步 估算 ， 表 示 与 其 他 
故事 相 比 ， 完 成 该 故事 所 需 的 工作 量 。 最 小 的 单位 是 故事 点 
(story point) ， 一 般 大 致 相当 于 一 个 “理想 的 人 天 ”(man- 
day) 。 





O 问 一 下 你 的 团队 , “如 宁可 以 投入 最 适合 的 人 员 来 完成 这 个 


故事 《人 数 要 适中 ， 通 常 为 2 个 ) ， 把 你 们 锁 到 一 个 屋子 
里 ， 有 很 多 食物 ， 在 完全 没有 打扰 的 情况 下 工作 ， 那 么 需 
要 几 天 ， 才 能 给 出 一 个 经 过 测试 验证 、 可 以 交付 的 完整 实 
现 呢 ? ”如 宁 答 案 是 “把 3 个 人 关 在 一 起 ， 大 约 需要 4 天 时 
间 ”， 那么 初始 估算 的 结果 就 是 12 个 故事 点 。 


O 不 需要 保证 这 个 估 值 绝对 无 误 《〈 比 如 两 个 故事 点 的 故事 就 
应 该 花 两 天 时 间 ) ， 而 是 要 保证 相对 的 正确 性 〈 即 ， 两 个 


把 的 故事 所 花费 的 时 间 应 该 是 四 个 点 的 故事 所 二 的 一 
半 ) 。 





= How to demo〔 如 何 做 演示 ) ， 它 大 略 描述 了 这 个 故事 应 该 如 
何在 sprint 演 示 上 进行 示范 ， 本 质 就 是 一 个 简单 的 测试 规 
范 。“ 先 这 样 做 ， 然 后 那样 做 ， 就 应 该 得 到 ..….…... 的 结果 。” 


口 ”、 如 果 你 在 使 用 TDD 测试 驱动 开发 ) ， 那 么 这 段 描述 束 可 
以 作为 验收 测试 的 伪 码 表示 。 


m Notes (注解 ) 相关 信息 、 解 释 说 明和 对 其 他 资料 的 引用 等 
等 。 一 般 都 非常 简短 。 


产品 BACKLOG (示例 ) 


Notes 

， 打开 存款 界面 ，| 需要 UML 顺序 
rep Ee 图 。 目 前 不 需要 
的 账户 余额 界面 ， 检 | 考虑 加 密 的 问题 
查 我 的 余额 增加 了 10 


欧元 

存 入 一 笔 款 项 。 返 回 | 免 大 规模 的 数据 
交易 页 面 ， 看 到 新 的 | SRW. MAF 
存款 显示 在 页 面 上 用 户 列 表 的 设计 
相似 





我 们 曾 试 过 很 多 字段 ， 但 最 后 及 现 ， 只 有 上 面 提 到 的 六 个 字段 我 们 
会 二 内 使 用 下 去 。 


oe. A 至 的 Excel 文 档 里 面 (是 为 了 多 个 用 
户 可 以 同时 编辑 它 AE e A A aN 
有 ， 但 是 我 们 并 不 想 把 其 他 用 户 排 斥 在 外 。 开 发 人 员 常 常 要 打开 这 个 
档 ， 弄 清 一 些 事情 ， 或 者 修改 估算 值 。 











基于 同样 原因 ， 我 们 没有 把 这 个 文档 放 到 版 本 控制 仓库 上 ， 而 是 放 
到 了 共 至 的 驱动 右 里 面 。 我 们 有 友 现 ， 要 想 保 证 多 用 户 同 时 编辑 而 不 会 导 
致 锁 操 作 或 是 合并 冲突 ， 这 是 最 简单 的 方式 。 





但 是 基本 上 其 他 所 有 的 制品 都 放 在 版 本 控制 仓库 中 。 


额外 的 故事 字段 


有 时 为 了 便于 产品 负责 人 判断 优先 级 别 ， 我 们 也 会 在 产品 backlog 中 
使 用 一 些 其 他 字段 。 





m Track (KaD 当前 故事 的 大 致 分 类 ， 例 如 “后 台 系 统 ” 或 “ 优 
化 ”。 这 样 产 品 负责 人 就 可 以 很 容易 选 出 所 有 的 “优化 ”条目 
把 它们 的 级 别 都 设 得 比较 低 。 类 似 的 操作 执行 起 来 都 很 方便 。 








= Components (组 件 ) 通常 在 Excel 文 档 中 用 “ 复 选 框 ”* 实 现 ， 
例如 数据库， 服务器 ， 客 户 端 *"。 团 队 或 者 产品 负责 人 可 以 在 
这 里 进行 标识 ， 以 明确 哪些 技术 组 件 在 这 个 故事 的 实现 中 会 被 
包含 进来 。 这 种 做 法 在 多 个 Scrum 团 队 协 作 的 时 候 很 有 用 一 一 
比如 一 个 后 台 系 统 团 队 和 一 个 客户 端 团队 一 一 他 们 很 容易 知道 
自己 应 当 对 哪些 故事 负责 。 








m Requestor 〈 请 求 者 ) 产品 负责 人 可 能 需要 记录 是 哪个 客户 
或 相关 干系 人 最 先 提出 了 这 项 需求 ， 在 后 续 开 发 过 程 中 向 他 提 
供 反 人 馈 。 


= Bug tracking ID (Bug 跟 踪 ID) 如 果 你 有 个 bug 跟 踩 系统 ， 
就 像 我 们 用 的 Jira 一 样 ， 那 么 了 解 一 下 故事 与 bug 之 间 的 直接 联 
RAAT MRA TE D. 


我 们 如 何 让 产品 backlog 停 留 在 业务 层次 上 


如 宁 产 品 负责 人 有 技术 相关 的 背景 ， 那 他 就 可 能 添加 这 样 一 个 故 
事 : “给 Events 表 添加 索引 ”。 他 为 哈 要 这么 做 ? 真正 的 潜在 目标 也 许 
古 “ 要 提高 在 后 全 系统 中 搜索 事件 表单 的 啊 应 速度 ”。 








到 后 面 我 们 可 能 会 发 现 : 索引 并 不 是 融 来 表单 速度 变 慢 的 瓶颈 。 也 
许 原 因 与 索引 完全 不 相干 。 指 出 如 何 ” 解决 问题 的 应 该 是 开发 团队 ， 产 
品 负责 人 只 需要 关注 业务 目标 。 

















只 要 发 现 这 种 面向 技术 的 故事 ， 我 一 般 都 会 问 产 品 负责 人 “但 是 为 
什么 呢 ”这 样 的 问题 ， 一 直 问 下 去 ， 直 到 我 们 发 现 内 在 的 目标 为 止 。 然 
后 再 用 真正 的 目标 来 改写 这 个 故事 〈“ 提 高 在 后 台 系统 中 搜索 并 生成 表 
单 的 啊 应 速度 ”) 。 最 开始 的 技术 描述 只 会 作为 一 个 注解 存在 (“为 事件 
表 添 加 索引 可 能 会 解决 这 个 问题 *)。 











第 3 革 ”我 们 怎样 准备 sprint 计 划 


Sprint 计划 的 这 一 天 很 快 就 要 到 来 了 。 有 个 教训 我 们 一 再 体会 : 在 
sprint 计 划 会 议 之 前 ， 要 确保 产品 backlog 的 井然 有 了 厅 。 





但 这 ”到底 是 什么 意思 ? 所 有 的 故事 都 必须 定义 得 完美 无 缺 ? 所 有 
的 估算 都 必须 正确 无 误 ? 所 有 的 先后 次 序 都 必须 固定 不 变 ? AS, AN, A 
不 是 这 样 ! 它 的 意思 是 “产品 backlog 必 须 存在 。”( 你 能 想象 到 这 一 点 
A? ) 











m 只 能 有 一 个 产品 backlog 和 一 个 产品 负责 人 【对 于 一 个 产品 而 
) 


HI 





me 所 有 重要 的 backlog 条 目 都 已 经 根据 重要 性 被 评 过 分 ， 不 同 的 重 
要 程度 对 应 不 同 的 分 数 。 


O 其实， 重要 程度 比较 低 的 backlog 条 目 ， 评 分 相同 也 没 关 
系 ， 因 为 它们 在 这 次 sprint 计 划 会 议 上 可 能 根本 不 会 被 提 
出 来 。 





O 无 论 任何 故事 ， 只 要 产品 负责 人 相信 它 会 在 下 一 个 sprint 实 
现 ， 那 它 束 应 该 被 划分 到 一 个 特有 的 重要 性 层次 。 


口 分 数 只 是 用 来 根据 重要 性 对 backlog 条 目 排 序 。 假 如 A 的 分 
数 是 20， 而 了 B 的 分 数 是 100， 那 仅仅 是 说 明 B 比 A 重 要 而 
己 ， 绝 不 意味 着 B 比 A 重 要 五 倍 。 如 果 B 的 分 数 是 21 而 不 是 
100， 含 义 也 是 一 样 的 ! 


O 最 好 在 分 数 之 间 留 出 适当 间隔 ， 以 防 后 面 出 现 一 个 C， 比 A 
重要 而 不 如 B 重 要 。 当 然 我 们 也 可 以 给 C 打 一 个 20.5 分 ， 但 
这 样 看 上 去 就 很 难看 了 ， 上 所 以 我 们 还 是 留 出 间 隅 来 ! 





四 ”产品 负责 人 应 当 理 解 每 个 故事 的 含义 〈 通 党 故事 都 是 由 他 来 纺 
写 的 ， 但 是 有 的 时 候 其 他 人 也 会 添加 一 些 请 求 ， 产 品 负责 人 对 
它们 划分 先后 次 序 ) 。 他 不 需要 知道 每 个 故事 具体 是 如 何 实现 
的 ， 但 是 他 要 知道 为 什么 这 个 故事 会 在 这 里 


VN we 
YER 


产品 负责 人 之 外 的 人 也 可 以 同 产 品 backlog 中 添加 故事 ， 但 是 他 们 


不 能 说 这 个 故事 有 多 重要 ， 这 是 产品 负责 人 独 有 的 权利 。 他 们 也 不 能 
添加 时 间 佑 算 ， 这 是 开发 团队 独 有 的 权利 。 





我 们 还 曾经 尝试 过 或 者 评估 过 其 他 方式 。 


加 ”使 用 Jira( 我 们 的 bug 跟 踪 系 统 ) 存放 产品 backlog。 但 是 大 多 数 
产品 负责 人 都 觉得 这 东西 操作 起 来 太 索 琐 了 。Excel 操 作 起 来 
简单 方便 ， 直 截 了 当 。 你 可 以 使 用 不 同 的 颜色 、 重 新 组 织 条 
目 、 在 特定 情况 下 添加 列 、 添 加 注解 和 导入 导出 数据 等 。 


四 ”使 用 VersionOne、ScrumWorks、XPlanner 这 种 敏捷 过 程 工具 
我 们 还 没有 测试 过 它们 ， 不 过 以 后 可 能 会 吧 ! 


at PAVE il ee sprintt ki 


四 ”无 休止 的 sprint 计 划 会 议 .……. 

m ” sprint 计划 会 议 日 程 

四 ”产品 负责 人 如 何 对 sprint 放 哪些 故事 产生 影响 
四 ”团队 怎样 决定 把 哪些 故事 放 到 sprint 里 面 

”使 用 计划 扑克 做 时 间 估 算 

四 ”明确 故事 内 容 

a 定 下 每 日 例会 的 时 间 地 点 

四 ”最 后 界限 在 哪里 

四 bug 跟踪 系统 vs. 产 品 backlog 


四 ”Sprint 计划 会 议 终于 结束 了 


Sprint 计划 会 议 非常 关键 ， 应 该 算是 Scrum 中 最 重要 的 活动 〈 这 当然 
征 我 的 主观 意见 ) 。 要 是 它 执行 得 不 好 ， 整 个 sprint 甚 至 都 会 被 毁 邱 。 


举办 sprint 计 划 会 议 ， 是 为 了 让 团队 获得 足够 的 信息 ， 能 够 在 几 个 
星期 内 不 受 干扰 地 工作 ， 也 是 为 了 让 产品 负责 人 能 对 此 有 充分 的 信心 。 








OK， 这 么 说 可 能 比较 模糊 。 其 实 ，sprint 计 划 会 议会 产生 一 些 实 实 
在 在 的 成 果 : 


m Sprint 目标 

四 ”团队 成 员 名单 ( 以 及 他 们 的 投入 程度 ， 如 果 不 是 100% 的 话 ) 
m sprint backlog《〈 即 Sprint 中 包括 的 故事 列表 ) 

m 确定 好 sprint 演 示 日 期 


m 确定 每 日 Scrum 会 议 的 时 间 和 地 点 


有 时 候 产品 负责 人 会 不 太 情 愿 跟 团 队 一 起 伦 上 几 个 小 时 制定 sprint 
计划 。“ 嘿 ， 小 伙 子 们 ， 我 想 要 的 东西 已 经 列举 出 来 了 ， 我 没 时 间 参 加 
你 们 的 计划 会 议 。” 这 可 是 个 非常 严重 的 问题 。 





为 什么 整个 团队 和 产品 负责 人 都 必须 要 参加 sprint 计 划 会 议 ? 原因 
在 于 ， 每 个 故事 都 含有 三 个 变量 ， 它 们 两 两 之 间 都 对 彼此 有 着 强烈 依 
赖 。 








下 图 中 的 范围 (scope) 和 重要 性 〈importance) 由 产品 负责 人 设 
置 。 估 算 Cestimate) 由 团队 设置 。 在 Sprint 计划 会 议 上 ， 经 过 团队 和 产 
品 负责 人 面对面 的 对 话 ， 这 三 个 变量 会 逐步 得 到 调整 优化 。 





yt [H] 


估算 重要 性 

会 议 启动 以 后 ， 产 品 负责 人 一 般 会 先 概括 一 下 希望 在 这 个 sprint 中 
达成 的 目标 ， 还 有 他 认为 最 重要 的 故事 。 接 下 来 ， 团 队 从 最 重要 的 故事 
开始 逐一 讨论 每 个 故事 ， 一 一 估算 时 间 。 在 这 个 过 程 中 ， 他 们 会 针对 范 
围 提出 些 重 要 问题 “删除 用 户 ' 这 个 故事 ， 需 不 需要 遍历 这 个 用 户 所 有 
尚未 执行 的 事务 ， 把 它们 统统 取消 ? ”有 时 答复 会 让 他 们 感到 惊讶 ， 促 
使 他 们 调整 估算 。 

















在 菏 些 情况 下 ， 团 队 对 故事 做 出 的 时 间 估 算 ， 跟 产品 负责 人 的 想法 
不 太一 样 。 这 可 能 会 让 他 调整 故事 的 重要 性 ， 或 者 修改 故事 的 范围 ， 导 
致 团队 重新 估算 ， 然 后 一 连 串 诸如 此 类 的 连锁 反应 。 


这 种 直接 的 协作 形式 是 Scrum 的 基础 ， 也 是 所 有 敏捷 软件 开发 的 基 
础 。 





如 果 产 品 负责 人 还 是 坚持 没 时 间 参 加 怎么 办 ? 一 般 我 会 按 顺 序 答 试 
下 面 的 策略 。 





四 ” 试 痢 让 产品 负责 人 理解 ， 为 什么 他 的 直接 参与 事 关 项 目 成 败 ， 
希望 他 可 以 改变 想法 。 


e 试 着 在 团队 中 找到 某 个 人 ， 让 他 在 会 议 中 充当 产品 负责 人 的 代 
表 。 告 诉 产品 负责 人 , “既然 你 没 法 来 开会 ， 我 们 这 次 会 让 Jeff 
代表 信安 出 SENTS 议 中 行使 权利 ， 改 变故 事 的 优先 级 
和 范围 。 我 建议 ， 你 最 好 在 会 议 开始 前 尽 可 能 跟 他 沟通 到 位 。 
如 果 你 不 喜欢 Jeff 当 代表 ， 也 可 以 推荐 其 他 人 ， 只 要 他 能 全 程 
参加 我 们 的 会 议 就 行 。” 


a 。” 试 痢 说 服 管理 团队 为 我 们 安排 新 的 产品 负 贡 人。 


四 ”推迟 sprint 的 局 动 日 期 ， 直 到 产品 负责 人 找到 时 间 参 会 为 上 上。 同 
时 拒绝 承 诡 任 何 交 付 。 让 团队 每 天 都 可 以 自由 做 他 们 最 想 做 的 
事情 。 





为 什么 不 能 在 质量 上 让 步 
在 上 面 的 三 角形 中 ， 我 有 意 忽 略 了 第 四 个 变量 


质量 。 





我 尽力 把 内 部 质量 和 外 部 质量 分 开 。 
e 外 部 质量 是 系统 用 户 可 以 感知 的 。 运 行 缓慢 、 让 人 迷糊 的 用 户 
界面 就 属于 外 部 质量 低劣 。 


e 内 部 质量 一 般 指 用 户 看 不 到 的 要 素 ， 它 们 对 系统 的 可 维护 性 有 
深远 影响 。 可 维护 性 包括 系统 设计 的 一 臻 性、 测试 尾 盖 率 、 代 
码 可 读 仁和 重 构 等 等 ato 
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量 差 的 系统 ， 外 部 质量 肯定 也 不 怎么 样 。 松 散 的 沙滩 上 怎么 可 能 建 起 精 
美的 楼 阁 ? 


我 把 外 部 质量 也 看 作 范 围 的 一 部 分 。 有 时 出 于 业务 考虑 ， 可 能 会 和 完 
发 布 一 个 系统 版 本 ， 其 用 户 界 面 给 入 的 感觉 可 能 比较 简陋 ， 而 且 反 应 也 
很 慢 ; 不 过 随后 会 发 布 一 个 干 奖 的 版 本 。 我 都 是 让 产品 负责 人 做 权衡 ， 
因为 他 是 负责 定义 项 目 范围 的 人 。 








不 过 内 部 质量 就 没什么 好 说 的 了 。 不 管 什么 时 候 ， 团 队 都 要 保证 系 
统 质量 ， 这 一 点 毋庸 置疑 ， 也 没有 任何 回旋 余地 。 现 在 如 此 、 将 来 如 
此 、 一 直 如 此 ， 直 到 永远 。 


那么 我 们 怎样 区 分 哪些 问题 属于 内 部 质量 ， 哪 些 属 于 外 部 质量 呢 ? 


假设 产品 负 贡 人 这 样 说 ,，“ 好 吧 ， 你 们 把 它 估 算 成 6 个 故事 点 也 行 
但 我 相信 : 一 定 能 够 找到 些 临 时 方案 ， 市 省 一 半 时 间 。 你 们 只 要 稍 和 动 
下 脑子 就 行 。” 


啊 哈 ! 他 想 把 内 部 质量 当 作 变量 来 处 理 。 我 是 怎么 知道 的 ?因为 他 
ee 但 不 想 为 缩减 范围 < 买单 *。， 'I 临 时 方 
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为 什么 不 允许 这 样 干 ? 


经 验 告 诉 我 : 牺牲 内 部 质量 是 一 个 糟糕 透顶 的 想法 。 现 在 布 省 下 来 
一 点 时 间 ， 接 下 来 的 日 子 里 你 就 要 一 直 为 它 付出 代价 。 一 旦 我 们 放松 要 
求 ， 允 许 代码 库 中 暗藏 问题 ， 后 面 就 很 难 恢复 质量 了 。 





磅 到 这 种 状况 ， 我 就 会 试 着 把 话题 转 回 到 范围 上 来 。“ 既 然 你 想 尽 
早 得 到 这 个 特性 ， 那 我 们 能 不 能 把 范围 缩小 一 点 ? 这 样 实现 时 间 就 能 缩 
短 。 也 许 我 们 可 以 简化 错误 处 理 的 功能 ， 把 高 级 错误 处 理 : 当 作 一 个 单 
独 的 故事 ， 放 到 以 后 再 实现 。 或 者 也 可 以 降低 其 他 故事 的 优先 级 ， 好 让 
我 们 集中 处 理 这 一 个 。” 





一 旦 产品 负 员 人 和 弄 清 楚 内 部 质量 是 不 可 能 让 步 的 ， 他 一 般 都 会 处 理 
E 


无 休止 的 sprint 计 划 会 议 .….……. 
在 sprint 计 划 会 议 中 最 困难 的 事情 是 : 

1. 人 们 认为 他 们 花 不 了 多 长 时 间 ; 
2.，.………. 但 他 们 会 的 ! 





Scrum 中 的 一 切 事情 都 有 时 间 盒 。 我 喜欢 这 条 简单 如 一 的 规则 ， 并 
一 直 力 求 贯彻 到 底 。 


假如 sprint 计 划 会 议 接 近 尾 声 ， 但 仍然 没有 得 出 sprint 目 标 或 者 sprint 
backlog， 这 时 该 怎么 办 ? 我 们 要 打上 断 它 么 ? 还 是 再 延长 一 个 小 时 ? 或 者 
到 时 间 就 结束 会 议 ， 然 后 明天 继续 ? 





这 种 事情 会 一 再 发 生 ， 尤 其 是 在 新 团队 身上 。 你 会 怎么 做 ? 我 不 知 
道 。 但 我 们 的 做 法 是 什么 ? 嗯 .………. 我 通常 会 直接 打上 断 会 议 ， 中 止 它 ， 让 
这 个 sprint 给 大 家 点 儿 徘 受 吧 。 有 具体 一 点 ， 我 会 告诉 团队 和 产品 负责 
人 :“ 辽 个 会 议 要 在 10 分 钟 以 后 结束 。 我 们 到 目前 为 止 还 没有 一 个 真正 
的 sprint 计 划 。 是 按照 已 经 得 出 的 结论 去 执行 ， 还 是 明 早 8 点 再 开 4 小 时 
的 会 ? ”你 可 以 猜 一 下 他 们 会 怎么 回答 .……: 0) 





我 也 试 过 让 会 议 延续 下 去 。 但 一 般 都 没 啥 效果 ， 因 为 大 家 都 很 累 
了 。 如 果 他 们 在 2 到 8 个 小 时 《不 管 多 久 ， 只 要 你 固定 好 时 间 长 度 就 可 
Dh) 内 都 没 整理 出 一 个 还 说 得 过 去 的 Sprint 计划 ， 那 么 再 来 一 个 小 时 他 
们 仍然 得 不 出 结论 。 我 们 也 可 以 明天 再 安排 一 次 会 议 一 一 但 大 家 都 已 经 
完全 失去 耐心 ， 只 想 启 动 这 个 sprint， 不 想 再 花 一 个 小 时 做 计划 。 如 果 
可 以 辣 顾 这 个 事实 ， 那 这 个 选择 也 确实 不 错 。 

















所 以 我 会 打 断 会 议 。 是 的 ， 这 个 sprint 让 大 家 不 太 好 过 。 但 我 们 应 
该 看 到 它 的 正面 影响 ， 整 个 团队 都 从 中 获 益 菲 浅 ， 下 个 sprint 计 划 会 议 
会 更 有 效率 。 另 外 ， 如 果 他 们 从 前 还 党 得 你 定 下 的 会 议 时 间 过 长 的 话 ， 
下 次 他 们 的 抵制 情绪 就 会 少 一 些 了 。 





学 会 按照 时 间 盒 安排 工作 ， 学 会 制定 合乎 情理 的 时 间 盒 ， 这 对 会 议 
长 度 和 sprint 长 度 同 样 有 帮助 。 


sprint 计 划 会 议 日 程 


在 sprint 计 划 会 议 之 前 先 为 它 初步 制定 一 个 时 间 表 ， 可 以 减少 打破 
时 间 盒 的 风险 。 


下 面 来 看 一 下 我 们 用 到 的 一 个 典型 的 时 间 表 。 
sprint 计 划 会 议 : 13: 00-17: 00( 每 小 时 休息 10 分 钟 》 


m 13: 00-13: 30 ”产品 负责 人 对 sprint 目 标 进 行 总 体 介 绍 ， 概 括 
产品 backlog。 确 定 演 示 的 时 间 和 地 点 。 


m 13: 30-15: 00 ”团队 估算 时 间 ， 在 必要 的 情况 下 拆 分 backlog 
条 目 。 产 品 负 责 人 在 必要 时 修改 重要 性 评分 。 理 清 每 个 条 目的 
含义 。 所 有 重要 性 高 的 backlog 条 目 都 要 填写 “如 何 演示 ”。 





m 15: 00-16: 00 团队 选择 要 放 入 sprint 中 的 故事 。 计 算 生产 
率 ， 用 作 核 查 工作 安排 的 基础 。 


= 16: 00-17: 00 为 每 日 scrum 会 议 ( 以 下 简称 每 日 例会 ) 安排 
国定 的 时 间 和 地 点 〈 如 果 和 上 次 不 同 的 话 ) 。 把 故事 进一步 拆 
分 成 任务 。 


这 个 日 程 绝 不 是 强制 执行 的 。ScrumMaster 根 据 会 议 进程 的 需要 ， 
可 以 对 各 个 阶段 的 子 进程 时 间 安 排 进行 调整 。 


确定 sprint 长 度 


sprint 演 示 日 期 是 sprint 计 划 会 议 的 产 出 物 ， 它 被 确定 下 来 以 后 ， 也 


就 确定 了 sprint 的 长 度 。 


那 sprint 应 该 多 长 才 好 ? 











虽 ， 时 间 短 惑 好。 公司 会 因此 而 变 得 “敏捷 >， 有 利于 随机 应 变 。 短 
的 sprint 三 短 反 馈 周 期 二 更 频 索 的 交付 三 更 频繁 的 客户 反馈 三 在 错误 方 
加 上 人 花 的 时 间 更 少 = 学 习 和 改进 的 速度 更 快 ， 众 多 好 处 接 是 而 来 。 








但 是 ， 时 间 长 的 Sprint 也 不 错 。 团 队 可 以 有 更 多 时 间 充 分 准备 、 解 
决 发 生 的 问题 、 继 续 达成 Sprint 目标 ， 你 也 不 会 被 接二连三 的 Sprint 计划 
会 议 、 演 示 等 等 压 得 不 堪 重 负 。 





产品 负责 人 一 般 会 喜欢 短 一 点 的 Sprint， 而 开发 人 员 喜 欢 时 间 长 的 
Sprint。 所 以 sprint 的 长 度 是 妥协 后 的 产物 。 做 过 多 次 实验 后 ， 我 们 最 终 
总 结 出 了 最 喜欢 的 长 度 : 三 个 星期 。 绝 大 部 分 团队 的 sprint 长 度 都 是 三 
周 。 它 不 长 不 短 ， 既 让 我 们 拥有 足够 的 敏捷 性 ， 又 让 团队 进入 <“ 流 ”中 
的 状态 ， 同 时 还 可 以 解决 sprint 中 出现 的 问题 。 








此 外 我 们 还 发 现 : 刚 开 始 要 试验 sprint 的 长 度 。 不 要 浪费 太 多 时 间 
做 分 析 。 选 一 个 可 以 接受 的 长 度 先 开始 再 说 ， 等 做 完 一 两 个 sprint 再 进 
行 调 整 。 








不 过 ， 确 定 了 目 己 最 喜欢 的 长 度 之 后 ， 葡 要 在 长 时 间 内 坚持 不 变 
。 经 过 几 个 月 的 实验 后 ， 我 们 发 现 3 个 星期 是 个 不 错 的 长 度 ， 于 是 我 们 
就 把 sprint 回 定 为 3 个 星期 ， 进 行 了 一 段 时 间 。 有 的 时 候 会 稍稍 感 党 有 点 
长 ， 有 的 时 候 感 觉 有 反 短 。 但 保持 住 这 个 长 度 以 后 ， 它 似乎 变 成 了 大 家 
共同 的 心跳 节奏 ， 每 个 人 都 感觉 很 舒服 。 这 段 时 间 内 也 无 需 讨 论 发 布 日 
期 乙 类 的 事情 ， 因 为 大 家 都 知道 : 每 过 三 周 都 会 有 一 个 发 布 。 





确定 sprint 目 标 


几 平 每 次 sprint 计 划 会 议 都 要 确定 sprint 目 标 。 在 sprint 计 划 会 议 进行 
中 ， 我 会 选 某 个 时 刻 问 一 个 问题 ,，“ 这 个 sprint 的 目标 是 什么 ?” 每 个 人 都 
目光 空洞 地 看 着 我 ， 产 品 负责 人 也 皱 起 眉头 ， 开 始 找 下巴 。 








出 于 某 些 原因 ， 制 定 sprint 目 标 确实 很 困难 ”。 但 我 友 现 即使 是 像 挤 
请 一 样 把 它 挤 出 来 ， 那 也 是 值得 的 。 半 死 不 活 的 目标 也 比 哈 都 没有 
强 。 这 个 目标 可 以 是 “ 挣 更 多 的 钱 ”， 或 者 “完成 优先 级 排 到 最 前 面 的 三 
个 故事 ”， 或 “打动 CEO”， 或 “把 系统 做 得 足够 好 ， 可 以 作为 beta 碑 发 布 
给 真正 的 用 户 使 用 *”， 或 “添加 基本 的 后 台 系 统 文 持 ”等 等 。 它 必须 用 业 
务 术 语 表达 ， 而 不 是 技术 词汇 ， 让 团队 以 外 的 人 也 能 够 理解 。 











sprint 目 标 需 要 回答 这 个 根本 的 问题 , “我 们 为 什么 要 进行 这 个 
sprint? 为 什么 我 们 不 直接 放假 算 了 ? ”要 想 从 产品 负责 人 的 口中 族 导 出 
sprint 目 标 ， 你 不 妨 一 字 不 基地 间 他 这 个 问题 看 看 。 





sprint 目 标 应 该 是 尚未 达成 的 。“ 打 动 CEO” 这 个 目标 不 错 ， 可 如 果 这 
个 系统 已 经 给 他 留 下 了 深刻 印象 ， 那 就 算 了 。 这 种 状况 下 大 家 都 可 以 放 
假 回 家 ，sprint 目 标 依 然 能 完成 。 





制订 sprint 计 划 的 时 候 ， 这 个 目标 可 能 看 上 去 既 思 缀 又 揭 强 ， 但 它 
在 Sprint 中 党 第 会 被 用 到 ， 到 那 时 大 家 融会 开始 对 他 们 应 该 做 啥 感到 困 
惑 。 如 果 有 多 个 Scrum 团 队 《 像 我 们 一 样 ) 开发 不 同 产 品 ， 你 可 以 在 一 
个 wiki 页 面 〈《 或 其 他 东西 ) 上 列 出 所 有 团队 的 Sprint 目标 ， 然 后 把 它们 放 
到 一 个 显著 位 置 上 ， 保 证 公司 所 有 人 《不 只 是 顶级 管理 层 ) 知道 公司 在 
干什么 ， 目 的 又 是 什么 ! 


决定 sprint 要 包含 的 故事 


决定 哪些 故事 需要 在 这 个 sprint 中 完成 ， 是 sprint 计 划 会 议 的 一 个 主 
要 活动 。 更 具体 地 说 ， 就 是 哪些 故事 需要 从 产品 backlog 找 贝 到 sprint 
backlog 中 ， 如 下 图 所 示 。 


r= in backlog Sprint 1 backlog 


= 





看 一 下 这 幅 图 。 每 个 矩形 都 表示 一 个 故事 ， 按 午 要 性 排序 。 最 重要 
的 故事 在 列表 顶部 。 和 矩形 尺寸 表示 故事 大 小 《〈 也 就 是 以 故事 点 估算 的 时 
HKE 。 括 号 的 高 度 表 示 团 队 估算 的 生产 率 (estimated velocity) , 
也 即 团队 认为 他 们 在 下 一 个 sprint 中 所 能 完成 的 故事 点 数 。 








右 侧 的 sprint backlog 是 产品 backlog 中 的 一 个 故事 快照 。 它 表示 团队 
在 这 个 sprint 中 承诺 要 完成 的 故事 。 





在 sprint 中 包含 多 少 故事 由 团队 ”决定 ， 而 不 是 产品 负责 人 或 其 他 
人 。 





这 便 引 发 了 两 个 问题 : 


1. 团队 怎么 决定 把 哪些 故事 放 到 sprint 里 面 ? 





2. 产品 负责 人 怎么 影响 他 们 的 决定 ? 


我 会 先 回答 第 二 个 问题 。 


产品 负责 人 如 何 对 sprint 放 哪些 故事 产生 影响 
假设 在 sprint 计 划 会 议 中 我 们 直到 下 图 所 示 的 情况 。 


产品 backlog 


> 


估算 的 生产 率 


mo | © 


产品 负责 人 很 失望 ， 因 为 故事 D 不 会 被 放 到 Sprint 里面 。 那 他 在 
Sprint 计划 会 议 上 能 做 些 什 么 ? 





首先 ， 他 可 以 重新 设置 优先 级 。 如 宋 他 给 故事 D 赋 了 予 最 高 的 重要 级 
别 ， 团 队 就 不 得 不 把 它 先 放 到 sprint 里 面 来 (在 这 里 需要 把 C 扔 出 去 )。 








其 次 ， 他 可 以 更 改 范围 一 一 缩小 故事 A 的 范围 ， 直 到 团队 相信 故事 


D 能 在 这 个 sprint 里 完成 为 止 。 








= A 
B 
: 估算 的 生产 率 估算 的 生产 率 
D 
= 一 
| _E | 


最 后 ， 他 还 可 以 拆 分 故事 。 产 品 负责 人 判断 出 故事 A 中 某 些 方面 实 
际 并 不 重要 ， 所 以 他 把 A 分 成 两 个 故事 A1 和 A2， 赋 给 它们 不 同 的 重要 级 


别 。 








产品 3 
A1 
估算 的 生产 率 
| D 
| 
| A2 


你 可 以 看 到 ， 虽 然 产 品 负责 人 在 正常 情况 下 不 能 控制 团队 的 估算 生 
产 率 ， 但 他 依然 有 很 多 种 方式 ， 对 sprint 中 放 入 哪些 故事 施加 影响 。 





以 怎样 决定 把 哪些 故事 放 到 sprint 里 面 
我 们 在 这 里 使 用 两 个 技术 。 


用 本 能 反应 来 估算 


m ScrumMaster: “伙计 们 ， 我 们 在 这 个 sprint 里 面 能 完成 故事 A 
吗 ? ”( 指 向 产品 backlog 中 最 重要 的 条 目 。) 








m Lisa: “ 呢 。 当 然 可 以 。 我 们 有 三 个 星期 ， 这 只 是 个 微不足道 的 
特性 。” 


= ScrumMaster: “OK， 那 加 上 B 怎 么 样 ? ”( 指 向 第 二 重要 的 条 
Ho ) 





m Tom 和 Lisa 一 起 回答 : “ 目 然 没 问题 。 ” 
= ScrumMaster: “OK， 那 A、B、C 一 起 呢 ? ” 


m Sam( 对 产品 负责 人 说 ) : “故事 C 要 包括 局 级 错误 处 理 么 ?” 





四 ”产品 负责 人 : “不 ， 你 现在 可 以 跳 过 它 ， 只 需要 完成 基本 的 错 
误 处 理 。” 


m Sam: “ 那 C 应 该 没 问 题 。” 


= ScrumMaster: “OK， 那 再 加 上 D 呢 ? ” 


= ScrumMaster: “有 多 少 把 握 ? 90%? 还 是 50%? ” 
m Lisa 和 和 Tom: “差不多 90%。” 

= ScrumMaster: “OK，D 也 加 进来 。 那 再 加 上 E 呢 ? ” 
m Sam: “也 许 吧 。” 

m= ScrumMaster: “90%? 50%? ” 

m Sam: “差不多 50%。” 

m Lisa: “我 没 把 握 。” 


m= ScrumMaster: “OK， 那 先 把 它 放 一 边 去 。 我 们 要 做 完 A、B、 
CAAD: 如 果 有 时 间 的 话 ， 当 然 还 可 以 做 完 E， 不 过 既然 没 人 指 
望 它 能 做 完 ， 所 以 我 们 不 会 把 它 算 到 计划 里 面 来 。 现 在 怎么 
样 ? 


me 所 有 人 : “OK! ” 





如 果 sprint 时 间 不 长 ， 小 团队 根据 直觉 进行 估算 可 以 收 到 很 好 的 效 


用 生产 率 计算 来 估算 


这 项 技术 包括 两 步 。 
1. 得 出 估算 生 产 率 。 
2. 计算 在 不 超出 估算 生产 率 的 情况 下 可 以 加 入 多 少 故事 。 








生产 率 是 “已 完成 工作 总 量 ” 的 一 个 衡量 方式 ， 其 中 每 一 个 条 目 都 是 
用 它 的 原始 估算 进行 衡量 的 。 


下 图 中 ， 左 边 是 sprint 启 动 时 的 估算 的 生产 率 ， 右 边 是 sprint 结 束 时 
的 实际 生产 率 ”。 每 个 矩形 都 是 一 个 故事 ， 里 面 的 数字 表示 这 个 故事 的 
原始 估算 。 


sprint 初期 sprint 结束 
8 Done! 8 
实际 生产 率 =18 
5 估算 的 生产 率 =26 Done!) 5 
5 Done! 5 
3 s | | 3 
5 Not started | 5 | 








注意 ， 这 里 的 实际 生产 率 建 立 在 每 个 故事 的 原始 ”估算 基础 之 上 。 
在 sprint 过 程 中 对 故事 时 间 进 行 的 修改 都 被 忽略 了 。 











我 已 经 能 听 到 你 的 抱 乱 了 :“ 那 不 是 采 得 没事 儿 干 么 ? PRY AEE, 
得 有 多 少 事 影响 生产 率 啊 ? 有 那么 人 原始 估算 能 
普 到 姥姥 家 去 、 范 围 变 化 了 连 个 啊 声 者 没有， 还 有 ， 儿 知道 从 哪个 香 兄 
里 就 能 出 来 个 东西 影响 我 们 ， 这 种 事 不 是 太 多 了 么 ! 











我 同意 ， 这 个 数字 并 不 精确 。 但 它 依然 很 有 用 ， 尤 其 是 与 喻 都 没有 


相 比 ， 感 党 就 更 明显 了 。 它 可 以 给 你 一 些 硬 生 生 的 事实 :“ 抛 开具 体 原 
因 ， 我 们 曾经 以 为 能 完成 这 么 多 ， 而 实际 完成 的 工作 与 当初 预计 的 还 是 
有 区 别 。” 


那个 sprint 里 面 差 不 多 (Almost) ”可 以 完成 的 故事 怎么 处 理 ? 为 什 
么 我 们 在 实际 生产 率 里 面 没 把 它 的 部 分 故事 点 数 算 进来 ? 呵呵 ， 这 就 突 
出 表现 了 Scrum 的 要 求 〈 实 际 上 也 是 敏捷 软件 开发 和 精益 制造 的 要 
求 ) : 把 事情 完全 做 完 ! 达到 可 以 交付 的 状态 ! 事情 只 做 了 一 半 ， 它 的 


价值 就 是 0 也许 还 会 是 负数 ) 。 你 可 以 看 看 Donald Reinertsen 的 
Managing the Design Factory 或 是 Poppendieck 的 书 ， 从 中 能 够 了 解 更 多 
ak o 


那 我 们 在 估算 生产 率 的 时 候 ， 动 用 了 何等 神奇 的 魔力 ? 


有 一 个 很 简单 的 办 法 : 看 看 团队 的 历史 。 看 看 他 们 在 过 去 几 个 
Sprint 里面 的 生产 率 是 多 少 ， 然 后 假定 在 下 一 个 sprint 里 面 生产 率 差 不 多 
ANE 





这 项 技术 也 叫 “ 昨 日 天 气 ”(yesterday's weather) 。 要 想 使 用 该 技 
术 ， 必 须 满足 两 个 条 件 : 团队 已 经 完成 了 儿 个 sprint〈 这 样 就 可 以 得 到 
统计 数据 ) ， 会 以 几乎 完全 相同 的 方式 《团队 长度 不 变 ， 工 作 状 态 等 条 
件 不 变 ) 来 进行 下 一 个 sprint。 当 然 也 不 是 绝对 如 此 。 








再 复杂 一 点 儿 ， 你 还 可 以 进行 简单 的 资源 计算 。 假 设 我 们 在 计划 一 
个 4 人 团队 3 星期 的 Sprint 〈15 个 工作 日 ) 。Lisa 会 休假 两 天 。Dave 只 能 投 
入 50%% 的 时 间 ， 另 外 还 会 休假 一 天 。 把 这 些 加 到 一 起 .……. 


AVAILABLE DAYS 
— a 


Tom 45 
LISA 13 
SAM 15 


Dave 7 
P 
SO AVAILABLE MAN-DAYS 
ee 这 个 sprint 一 共有 50 个 可 用 的 人 -天 。 


这 是 我 们 的 估算 生产 率 么 ? 不 ! 我 们 估算 的 单位 是 故事 点 〈story 
point) ， 差 不 多 可 以 对 应 于 “理想 化 的 人 -天 ”。 一 个 理想 化 的 人 -天 是 完 
美 、 局 效 、 不 受 打扰 的 一 天 ， 但 这 种 情况 太 少 见 了 。 我 们 还 必须 考虑 到 
各 种 因素 ， 例 如 要 把 未 计划 到 的 工作 添加 到 sprint 中 、 人 们 患 病 不 能 


作 等 等 。 





那 我 们 的 估算 生产 率 肯定 要 比 50 少 了 。 少 多 少 呢 ? 我们 引入 “投入 
程度 ”(focus factor) 这 个 词 来 看 一 下 。 
THIS SPRINT'S ESTIMATED VELOCITY: 
(AVAILABLE MAN-DAYS) X (FOCUS FACTOR) = (ESTIMATED VELOCITY) 
投入 程度 用 来 估算 团队 会 在 sprint 中 投入 多 少 精力 。 投 入 程度 低 ， 


就 表示 团队 估计 会 受到 很 大 和 干扰， 或 者 他 们 觉得 自己 的 时 间 佑 算 太 过 理 
想 化 。 


要 想 得 出 一 个 合理 的 投入 程度 ， 最 好 的 办 法 就 是 看 看 上 一 个 sprint 
的 值 《 对 前 几 个 sprint 取 平均 值 自 然 更 好 ) 。 


LAST SPRINT'S FOCUS FACTOR: 


sae ened (ACTUAL VELOCITY) 
= NE et 
(AVAILABLE MAN-DAYS) 


把 上 一 个 sprint 中 完成 的 所 有 故事 的 原始 估算 加 起 来 ， 得 到 的 和 就 
是 实际 生产 率 。 


假设 在 上 个 Sprint 里面 ， 由 Tom，Lisa 和 Sam 组 成 的 9 人 团队 在 3 个 星 
期 内 工作 了 45 个 人 -天 ， 一 共 完 成 18 个 故事 点 。 现 在 我 们 要 为 下 一 个 
Sprint 估算 一 下 生产 率 。 新 伙计 Dave 的 加 入 让 情况 更 复杂 了 。 把 假期 和 
新 成 员 算 上 ， 我 们 在 下 个 sprint 中 一 共有 50 个 人 -天 。 


LAST SPRINT'S FOCUS FACTOR: THIS SPRINT'S ESTIMATED VELOCITY: 
Qo- 18 STORY POINTS 50 MAN-OAYS x 40% 420 STORY POIN 
45 MAN-DAYS Pi 


< 
mw 
和 -* 
at ee eae T EE _ 
“een. eC wee eee eee eeeeeacee® 
esse 


从 上 面 的 公式 中 可 以 看 出 ， 下 个 sprint 的 估算 生产 率 是 20 个 故事 
点 。 这 表明 团队 这 个 sprint 中 所 能 做 的 故事 点 数 之 和 不 能 超过 20。 


当前 sprint 之 初 





5 

8 当前 sprint 包含 
19 个 故事 点 

3 

3 | 

5 | 不 宜 放 入 

3 | 当前 sprint 


在 这 种 情况 下 ， 团 队 可 以 选择 前 4 个 故事 ， 加 起 来 一 共 19 个 故事 
点 ; 或 者 选 前 5 个 故事 ， 一 共 24 个 故事 点 。 我 们 假设 他 们 选 了 4 个 故事 ， 
因为 它 离 20 最 近 。 如 果 不 太 确定 ， 那 就 再 少 选 些 好 了 。 





因为 这 4 个 故事 加 起 来 一 共 19 个 故事 点 ， 所 以 他 们 在 这 个 sprint 中 最 
后 的 估算 生产 率 就 是 19。 


“昨日 天 气 ” 用 起 来 很 方便 ， 但 需要 考虑 一 些 音 识 。 如 果 上 一 个 Sprint 
干 得 很 糟 ， 是 因为 大 部 分 成 员 都 病 了 一 星期 。 那 你 差不多 可 以 放心 假设 
这 次 运气 不 会 那么 坏 ， 给 这 个 sprint 设 个 高 点 的 投入 程度 如果 团 队 最 
近 刚 装 了 一 个 执行 速度 快 如 闪电 的 持续 集成 系统 ， 那 你 也 可 以 因此 提高 
一 下 投入 程度 ， 如 果 有 新 人 加 入 这 个 sprint， 就 得 把 他 的 培训 占用 的 精 
力也 算 进 来 ， 降 低 投 入 程度 ， 等 等 。 


只 要 条 件 允许 ， 你 就 应 该 看 看 从 前 的 sprint， 计 算出 平均 数 ， 这 样 


可 以 得 到 更 合理 的 估算 。 


如 琳 这 是 个 全 新 的 团队 ， 没 有 任何 数据 怎么 办 ? 你 可 以 参考 一 下 在 
类 似 条 件 下 工作 的 团队 ， 他 们 的 投入 程度 数值 是 多 少 。 


如 果 没 有 其 他 团队 可 以 参考 怎么 办 ? 随便 猜 一 个 数 作 为 投入 程度 
吧 。 上 毕竟 这 个 猜测 只 会 在 第 一 个 sprint 里 面 使 用 。 过 了 这 次 以 后 你 就 有 
了 历史 数据 可 以 分 析 ， 然 后 对 投入 程度 和 佑 算 生 产 率 做 出 不 断 的 改进 。 


我 在 新 团队 中 使 用 的 “默认 ”投入 程度 通常 是 70%， 因 为 这 是 其 他 大 
多 数 团 队 都 能 达到 的 数值 。 


我 们 用 的 是 哪 种 估算 技术 


上 面 提 到 了 好 几 种 技术 一 一 直觉 反应 、 基 于 昨日 天 气 的 生产 率 计 
算 、 基 于 可 用 人 -天 和 估算 投入 程度 的 生产 率 计算 。 











那 我 们 用 的 是 什么 ? 

一 般 我 们 都 是 结合 起 来 用 。 花 不 了 多 大 功夫 。 

我 们 审视 上 个 sprint 的 投入 程度 和 实际 生产 率 。 我 们 审视 这 个 sprint 
总 共 可 用 的 资源 ， 估 算 一 个 投入 程度 。 我 们 讨论 这 两 个 投入 程度 之 间 的 
区 别 ， 必 要 时 进行 调整 。 

大 致 有 了 一 个 要 放 入 sprint 的 故事 列表 以 后 ， 我 再 进行 “直觉 反应 ”的 
检查 。 我 要 求 他 们 暂时 筷 抒 数字 ， 感 觉 一 下 : 在 一 个 sprint 里 一 口 咬 这 
么 多 东西 会 不 会 难以 下 咽 。 如 果 觉 得 太 多 了 ， 那 就 移 走 一 两 个 故事 。 反 


当天 结束 以 前 ， 只 要 得 出 哪些 故事 要 放 到 sprint 里 面 ， 我 们 就 算 完 
成 了 目标 。 投 入 程度 、 资 源 可 用 性 和 估算 生产 率 只 是 用 来 达成 这 个 目标 
的 手段 。 


我 们 为 何 使 用 索引 卡 


在 大 多 数 sprint 计 划 会 议 上 ， 大 家 都 会 讨论 产品 backlog 中 的 故事 细 
六。 对 故事 进行 估算 、 重 定 优先 级 、 进 一 步 确认 细节 、 拆 分 ， 等 等 都 会 
在 会 议 上 完成 。 

















我 们 是 怎样 实际 操作 的 呢 ? 


咖 ， 也 许 有 人 认为 是 这 样 的。 团队 打开 投影 仪 ， 把 用 Excel 保 存 的 
backlog 投 在 场 上 ， 然 后 一 个 人 《通常 是 产品 负 贡 人 或 者 ScrumMtaster) 
拿 过 键盘 ， 嘟 吹 着 把 一 个 个 故事 讲 一 和 遍 ， 请 大 家 进行 讨论 。 团 队 和 产品 
负责 人 讨论 过 优先 级 和 具体 细节 以 后 ， 拿 着 键盘 的 人 会 在 Excel 上 直接 
进行 修改 。 








听 起 来 不 错 ? 呵 ， 纯 粹 扯淡 。 更 糟 的 是 ， 团 队 一 般 都 是 到 了 会 议 结 
束 前 才 发 现 他 们 一 直 在 扯淡 ， 到 最 后 还 没 把 故事 看 上 一 通 呢 ! 


要 想 收 到 好 的 效果 ， 不 妨 创 建 一 些 索 引 卡 ， 把 它们 放 到 增 上 《或 
RART E) 
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这 种 用 户 体验 比 计算 机 和 投影 仪 好 得 多 ， 理 由 如 下 。 


大 家 站 起 来 四 处 走动 三 > 他 们 可 以 更 长 时 间 地 保持 清醒 ， 并 留心 
会 议 进展 。 





他 们 有 更 多 的 个 人 参与 感 〈 而 不 是 只 有 那个 拿 着 键盘 的 家 伙 才 
A) o 


多 个 故事 可 以 同时 编辑 。 





重新 划分 优先 级 变 得 易如反掌 一 一 挪动 索引 卡 束 行 。 


会 议 结束 后 ， 索 引 卡 可 以 拿 出 会 议 室 ， 贴 在 墙 上 的 任务 板 上 
《参见 第 6 章 “ 我 们 怎样 编写 Sprint backlog”) 。 


你 可 以 手写 索引 卡 〈 像 我 们 一 样 ) ， 也 可 以 用 简单 的 脚本 从 产品 
backlog 中 直接 生成 可 以 打印 的 索引 卡 。 


Backlog item #55 
Importance 


Deposit 30 


Notes 





Need a UML sequence diagram. No need Estimate 
to worry about encryption for now. 


How to demo 


Log in, open deposit page, deposit €10, go 
to my balance page and check that it has 
increased by €10 





在 我 的 博客 上 有 这 种 脚本 ， 地 址 是 
http://blog.crisp.se/henrikkniberg 。 


重要 事项 :sprint 计划 会 议 结 束 后 ， 我 们 的 ScrumMaster 会 手工 更 新 
Excel 中 的 产品 backlog， 以 反映 故事 索引 卡 中 发 生 的 变化 。 这 确实 给 管 
理 者 带 来 了 一 点 兵 烦 ,但 是 考虑 到 用 了 物理 索引 卡 以 后 ，sprint 计 划 会 
议 的 效率 得 到 了 大 幅度 提高 ， 这 种 做 法 还 是 完全 可 以 接受 的 。 





注意 这 里 的 “重要 性 ”(Importance) 字段 。 它 和 打印 时 Excel 中 产品 
backlog 所 记录 的 “重要 性 ”是 一 样 的 。 把 它 放 到 卡片 上 ， 可 以 帮助 我 们 根 
据 重 要 性 给 卡片 排序 (我 们 一 般 把 最 重要 的 放 到 左边 ， 依 次 同 右 排 
列 ) . ARE, 一旦 卡 厂 被 放 到 墙 上 ， 那 就 可 以 暂时 忽略 它 的 重要 性 评 
分 ， 根 据 它 们 摆 放 的 相对 位 置 ， 来 对 比 彼此 的 重要 性 。 如 果 产 品 负 贡 人 
交换 了 两 张 卡 片 ， 先 不 要 浪费 时 间 在 纸 上 更 新 数字 ， 只 要 确保 会 议 结 
后 在 产品 backlog 做 更 新 就 可 以 。 








把 故事 拆 分 成 任务 后 ， 时 间 佑 算 就 变 得 更 容易 《也 更 精确 ) 了 。 


这 个 用 索引 卡 来 做 就 又 方便 又 漂亮 。 你 可 以 把 团队 分 成 不 同 的 二 人 
组 ， 让 他 们 每 组 同时 各 自 拆 分 一 个 故事 。 


我 们 用 即时 贴 贴 在 每 个 故事 的 下 方 ， 每 张 即 时 贴 表示 这 个 故事 中 的 
— “MEF 
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我 们 不 会 让 任务 拆 分 出 现在 产品 backlog 中 ， 原 因 如 下 。 





四 ”任务 拆 分 的 随机 性 比较 强 ， 在 sprint 进 行 中 ， 它 们 第 常会 发 生变 
化 ， 不 断 调整 ， 所 以 保持 产品 backlog 的 同步 很 让 人 头 大 。 





四 ”产品 负责 人 不 需要 关心 这 种 程度 的 细节 。 


任务 拆 分 的 即时 贴 可 以 和 故事 索引 卡 一 起 ， 在 sprint backlog 中 被 直 
接 重 用 。 “参见 第 6 章 “ 我 们 怎样 编写 sprint backlog”. ) 


有 一 点 很 重要 : 产品 负 贡 人 和 团队 需要 对 “完成 ”(done) 有 一 致 的 
定义 。 所 有 代码 被 check 让 以 后 ， 故 事 就 算 完 成 了 吗 ? 还 是 被 部 车 到 测 
试 环境 中 ， 经 过 集成 测试 组 的 验证 以 后 才 算 完成 ? 我 们 尽 可 能 使 用 这 样 
的 定义 :“ 随 时 可 以 上 线 ”"”， 不 过 有 时候 我 们 也 这 样 说 :“ 已 经 部 署 到 测 
试 服务 器 上 ， 人 准备 进行 验收 测试 ”。 





最 开始 我 们 用 的 是 比较 详细 的 检查 列表 。 现 在 我 们 第 说 “如 果 Scrum 
团队 中 的 测试 人 员 说 可 以 ， 那 这 个 故事 束 算 完成 了 ”。 然 后 员 任 束 到 了 
测试 人 员 喘 上 ， 他 需要 保证 团队 理解 了 产品 负责 人 的 意图 ， 要 保证 故事 
的 “完成 ”情况 可 以 符合 大 家 认可 的 定义 。 


我 们 慢 慢 意识 到 ， 不 能 把 所 有 的 故事 都 一 概 而 论 。“ 奏 询 用 户 表 
单 ” 跟 “操作 指南 ”这 两 个 故事 的 处 理 方式 就 有 很 大 差异 。 对 后 者 ,，“ 完 
成 ”的 定义 可 能 束 是 简单 的 一 句 话 一 一 “被 运营 团队 认可 ”。 所 以 说 ,日 
常 的 一 些 认识 往往 要 好 过 正式 的 检查 列表 。 














如 宁 你 种 党 对 怎样 定义 完成 感到 困惑 〈 束 像 我 们 刚 开 始 一 样 ) ， 你 
或 许 应 该 在 每 个 故事 上 都 添加 一 个 字段 ， 起 名 为 “何谓 完成 ”。 





使 用 计划 扑克 做 时 间 估 算 


估算 是 一 项 团队 活动 
为 啥 要 每 个 人 都 参加 ? 








通常 每 个 成 员 痢 会 参与 所 有 故事 的 估算 。 


四 ”在 计划 的 时 候 ， 我 们 一 般 都 还 不 知道 到 底 谁 会 来 实现 哪个 故事 
的 哪个 部 分 。 





四 ”每 个 故事 一 般 有 好 几 个 人 参与 ， 也 包括 不 同类 型 的 专长 《用 户 
界面 设计 、 编 程 、 测 试 等 )。 








四 ”团队 成 员 必 须要 对 故事 内 容 有 一 定 的 理解 才能 进行 估算 。 要 求 
每 个 人 都 做 估算 ， 我 们 就 可 以 确保 他 们 都 理解 了 每 个 条 目的 内 
容 。 这 样 就 为 大 家 在 sprint 中 相互 帮助 夯实 了 基础 ， 也 有 助 于 
故事 中 的 重要 问题 被 尽早 发 现 。 


四 ”如 末了 要 求 每 个 人 都 对 故事 做 估算 ， 我 们 就 会 冲冲 发 现 两 个 人 对 
同一 个 故事 的 估算 结果 差异 很 大 。 我 们 应 该 尽早 发 现 这 种 问题 
并 就 此 进行 讨论 。 
如 果 证 整个 团队 进行 估算 ， 通 种 那 个 对 故事 理解 最 透彻 的 人 会 第 一 
个 有 发言。 不 笠 的 是 ， 这 会 严重 影响 其 他 人 的 估算 。 


有 一 项 很 优秀 的 技术 可 以 避免 这 一 点 一 一 它 的 名 字 是 计划 扑克 (我 
记得 是 Mike Cohn 创 造 出 来 这 个 名 字 的 ) 。 


每 个 人 都 会 得 到 如 下 图 所 示 的 13 张 纸牌 。 在 估算 故事 的 时 候 ， 每 个 
人 都 选 出 一 张 纸牌 来 表示 他 的 时 间 佑 算 《〈 以 故事 点 的 方式 表示 ) ， 并 把 
它 正 面 明 下 扣 在 桌 上 。 所 有 人 都 完成 以 后 ， 桌 上 的 纸牌 会 被 同时 揭 开 。 





这 样 每 个 人 都 会 被 迫 进 行 自 我 思考 ， 而 不 是 依赖 于 其 他 人 估算 的 结果 。 





如 果 在 两 个 估算 之 间 有 着 巨大 差异 ， 团 队 就 会 就 此 进行 讨论 ， 并 试 
图 让 大 家 对 故事 内 容 达 成 共识 。 他 们 也 许 会 进行 任务 分 解 ， 之 后 再 重新 
估算 。 这 样 的 循环 会 往复 进行 ， 直 到 时 间 估 算 趋 于 一 致 为 止 ， 也 就 是 每 
个 人 对 这 个 故事 的 估算 都 差不多 相同 。 


重要 的 是 ， 我 们 必须 提醒 团队 成 员 ， 他 们 要 对 这 个 故事 中 所 包含 的 
全 部 工作 进行 估算 ， 而 不 是 “他 们 上 自己 负责 ?的 部 分 工作 。 测 试 人 员 不 能 
只 估算 测试 工作 。 


注意 ， 这 里 的 数字 顺序 不 是 线性 的 。 例 如 在 40 和 100 之 间 就 没有 数 
字 。 为 什么 这 样 ? 


这 是 因为 ， 一 旦 时 间 的 估算 值 比较 大 ， 其 精确 度 就 很 难 把 握 ， 这 样 


做 就 可 以 避免 人 们 对 估算 精确 度 产 生 错 误 的 印象 。 如 果 一 个 故事 的 估算 
值 是 差不多 20 个 故事 点 ， 它 到 底 应 该 是 20 还 是 18 还 是 21， 其 实 无 关 紧 

要 。 我 们 知道 的 就 是 它 是 一 个 很 大 的 故事 ， 很 难 估 算 。 所 以 20 只 是 一 个 
粗略 估计 。 











要 进行 更 精确 的 估算 ? 那 束 把 故事 分 折 ， 去 估算 那些 更 小 的 故 
事 ! 


另外 ， 你 也 不 能 搞 那 种 把 5 和 2 加 起 来 得 到 7 的 把 戏 。 要 么 选 5， 要 么 
选 8， 没 有 7。 


下 面 这 些 卡 片 比较 特殊 。 





四 0 一 “这 个 故事 已 经 完成 了 ”或 者 “这 个 故事 根本 没 喻 东西 ， 几 分 
钟 就 能 搞定 ”。 


E ? 一“ 我 一 点 概念 都 没有 。 没 想法 。 
四 ”咖啡 杯 二 “我 太 累 了 ， 先 其 会 吧 


明确 故事 内 容 


在 sprint 演 示 会 议 上 ， 团 队 自 窒 地 演示 了 一 个 新 特性 ， EP LT 
人 却 皱 起 眉头 ,“ 呢 ， 看 上 去 不 错 ， 但 这 不 是 我 要 的 ! “发 生 这 种 事情 
可 真是 糟 透 了 ! 





怎样 才能 让 产品 负 贡 人 和 团队 对 故事 有 同样 的 理解 ?或 者 保证 所 有 
的 团队 成 员 对 每 个 故事 都 有 同样 的 理解 ? 嗯 ， 这 可 没 法 做 到 。 不 过 还 是 
有 些 简 单 技 术 ， 可 以 识别 出 最 明显 的 误解 。 最 简单 的 办 法 瓯 是 确保 每 个 
故事 的 所 有 字段 都 被 填 满 〈 更 精确 地 说 ， 这 里 提 到 的 是 具有 高 优先 级 ， 
应 该 在 这 个 Sprint 里 面 完 成 的 故事 ) 。 





例 1 


团队 和 产品 负责 人 都 对 Sprint 计划 很 满意 ， 打 算 结束 会 议 。 这 时 
ScrumMaster 问 了 一 个 问题 , “等 一 下 ， 还 有 个 “添加 用 户 的 故事 没有 佑 
算 时 间 呢 ， 把 它 解 决 了 吧 ! ” 几 轮 计划 扑克 以 后 ， 团 队 意 见 达 成 一 致 ， 
认为 这 个 故事 需要 20 个 故事 点 ; 产品 负责 人 却 站 了 起 来 ， 说 话 因为 生 


气 也 走 了 调 :“ 什 、 什 、 什 么 ? ! ”经 过 几 分 钟 的 激烈 争吵 ， 最 后 发 现 
古 团 队 错误 理解 了 “增加 用 户 ” 这 个 故事 的 范围 ， 他 们 以 为 这 表示 “要 有 
漆 壳 的 Web 界 面 来 添加 、 删 除 、 移 除 和 奉 询 用 户 ?”， 但 是 产品 负责 人 
a “通过 手写 SQL 操 作 数 据 库 来 添加 用 户 ”?”。 他 们 重新 进行 评估 ， 
给 它 5 个 故事 点 ， 达 成 共识 。 














例 2 


团队 和 产品 负责 人 都 对 Sprint 计划 很 满意 ， 打 算 结 束 会 议 。 这 时 
ScrumMaster 问 了 一 个 问题 ,，“ 等 一下， 还 有 一 个 “添加 用 户 : 的 故事 ， 它 


AiR ANNE? "ME ALE ZA, AER, “WE, CBS 
Webuii, AIR... Pm Ao ATT E Sa, “Cae Webi A?! 
不 不 不 ， 这 个 功能 跟 Web 站 点 一 点 关系 都 没有 ， 你 给 技术 管理 员 提 供 
个 傻瓜 都 能 用 的 SQL 脚 本 就 行 。” 














“如 何 演示 ”这 段 描述 可 以 《而 且 应 该 ) 非常 精简 ! 不 然 你 就 没 法 
按时 结束 sprint 计 划 会 议 。 基 本 上 ， 它 就 是 用 最 平 白 浅显 的 语言 ， 来 描 
述 如 何 手工 执行 最 典型 的 测试 场景 。“ 先 这 样 ， 然 后 那样 ， 最 后 验证 这 
= ” 











REM, BEALE TAT, AAS eS ACE Ss Ye EB AY sc 
严重 的 误解 。 这 种 事 发 现 得 越 早 越 好 ， 不 是 么 ? 


把 故事 拆 分 成 更 小 的 故事 


故事 不 应 该 太 短 ， 也 不 应 太 长 “从 估算 的 角度 出 有 发) 。 如 果 你 有 一 
YEO. Tit AIS, ABRAM ies ROA OW ENS So 与 
之 相反 ，40 个 点 的 故事 ， 到 最 后 很 可 能 只 能 部 分 完成 ”， 这 样 不 会 为 公 
司 带 来 任何 价值 ， 只 会 增加 管理 成 本 。 进 一 步 来 说 ， 如 果 你 们 估算 的 生 
产 率 是 70， 而 最 局 优先 级 的 两 个 故事 部 是 40 个 故事 点 ， 那 做 计划 可 束 有 
PITT o 








摆 在 团队 面前 的 只 有 两 种 选择 : 要 么 只 选 一 个 条 目 ， 完 成 当初 允诺 








的 工作 后 ， 还 有 不 少 空 羡 时间， 导致 承 诡 不 足 Cunder-committing) ; 
要 么 两 个 条 目 都 选 上 ， 最 后 无 法 完成 当初 允诺 的 工作 量 ， 导 致 过 度 承 话 


Cover-committing) 。 











我 发 现 很 大 的 故事 基本 上 都 能 进行 拆 分 。 只 要 确定 每 个 小 故事 依然 
可 以 交付 业务 价值 就 行 。 

我 们 常常 都 力求 保证 故事 的 大 小 在 2 至 8 个 人 一 天 之 间 。 一 个 普通 团 
队 的 生产 率 大 约 是 40 一 60， 所 以 大 概 每 个 sprint 可 以 完成 10 个 故事 。 有 
时 会 减少 到 5 个 ， 有 时 也 会 多 到 15 个 。 处 在 这 个 数量 范围 之 间 的 索引 卡 
是 比较 容易 管理 的 。 


把 故事 拆 分 成 任务 








等 一 下 。“ 任 务 * 和 "故事 * 的 区 别 是 什么 呢 ? 嗯 ， 这 个 问题 问 得 不 
错 。 





区 别 很 简单 。 故 事 是 可 以 交付 的 东西 ， 是 产品 负责 人 所 关心 的 。 储 
务 是 不 可 交付 的 东西 ， 产 品 负责 人 对 它 也 不 关心 。 





在 下 图 的 例子 中 ， 故 事 被 拆 分 成 更 小 的 故事 : 


| ADDVEDIT QUERY 
| USE? USEQS 


下 图 是 把 故事 拆 分 成 任务 的 例子 。 














Clarify Write 


requirements 












Find 
reporting || Implement 
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Integration | Implement 
the query 
form 


我 们 会 看 到 一 些 很 有 趣 的 现象 。 





test | Design 
case GUI 





国产 组 建 的 Scrum 团 队 不 愿意 花 时 间 来 预先 把 故事 拆 分 成 任务 。 





有 些 人 觉得 这 像 是 滩 布 式 的 做 法 。 


四 ”有 些 故事 ， 大 家 都 理解 得 很 清楚 ， 预 先 拆 分 还 
样 简 单 。 


` 是 随后 拆 分 都 一 


四 ”这 种 类 型 的 拆 分 第 第 可 以 友 现 一 些 会 导致 时 间 估 算 增 加 的 工 


作 ， 最 后 得 出 的 sprint 计 划 会 更 贴近 现实 。 





四 ”这 种 预先 拆 分 可 以 给 每 日 例会 的 效率 带 来 显著 提高 (参见 第 8 
章 “ 我 们 怎样 进行 每 日 例会 >) 。 


四 ”即使 拆 分 不 够 精确 ， 而 且 一 旦 开始 具体 工作 ， 事 先 的 拆 分 结果 
也 许 会 发 生变 化 ， 但 我 们 依然 可 以 得 到 以 上 种 种 好 处 。 


所 以 ， 我 们 试 着 把 sprint 计 划 会 议 的 时 间 帮 到 足够 长 ， 保 证 有 时 间 
进行 任务 拆 分 ， 但 如 果 时 间 不 够 的 话 ， 我 们 就 不 做 了 。 参加 下 面 
的 “最 后 界限 在 哪里 *) 。 


注意 一 一 我 们 在 实践 TDD 测 试 驱动 开 友 )〉 ， 所 以 几乎 每 个 故事 的 
第 一 个 任务 都 是 “编写 一 个 失败 的 测试 ”， 而 最 后 一 个 任务 是 “ 重 构 ”(〈 提 
高 代码 的 可 读 性 ， 消 除 重 复 ) 。 





定 下 每 日 例会 的 时 间 地 点 


sprint 计 划 会 议 有 一 个 产物 常常 被 人 们 忽略 :“ 确 定 的 时 间 和 地 点 ， 
以 供 举 办 每 日 例会 >。 没 有 这 一 点 ， 你 的 sprint 束 会 有 个 “开门 黑 ?。 实 际 
上 ， 每 个 人 都 是 在 当前 sprint 的 第 一 个 每 日 例会 上 决定 怎样 开始 工作 。 


我 喜欢 早上 开会 。 不 过 我 得 承认 ， 我 们 没有 真正 试 过 在 下 午 或 者 中 
午 进行 每 日 例会 。 





在 下 午 开 每 日 例会 的 缺点 : ”早上 来 工作 的 时 候 ， 你 必须 试 着 回忆 
起 你 昨天 对 别人 说 过 今天 要 做 什么 。 





在 上 午 开 每 日 例会 的 缺点 : ”早上 来 工作 的 时 候 ， 你 必须 试 着 回忆 
起 你 昨天 做 了 些 什么 ， 这 样 才 能 跟 别 人 讲 。 





我 的 看 法 是 ， 第 一 个 缺点 更 糟 ， 因 为 最 重要 的 事情 是 你 打算 干 AF 
么 ， 而 不 是 已 经 干 了 什么 。 











我 们 的 默认 做 法 是 选 一 个 大 家 都 不 会 有 异议 的 最 早 时 间 。 一 般 是 
9: 00，9: 30 或 者 10: 00。 最 关键 的 是 ， 这 必须 是 每 个 人 都 能 完全 接受 
的 时 间 。 











最 后 界限 在 哪里 


OK， 现 在 时 间 已 经 用 完了 。 如 果 时 间 不 够 的 话 ， 那 么 我 们 该 把 哪 
些 本 该 做 的 事情 砍 掉 呢 ? 


TI 


恩 ， 我 总 是 用 下 面 这 个 优先 级 列表 。 


优先 级 1: ”sprint 目标 和 演示 日 期 。 这 是 启动 sprint 最 起 人 码 应 该 有 的 
东西 。 团 队 有 一 个 目标 ， 一 个 结束 日 期 ， 然 后 就 可 以 马上 根据 产品 
backlog 开 始 工作 。 没 错 ， 这 是 不 像 话 ， 你 应 该 认真 考虑 一 下 明天 再 开 个 
新 的 sprint 计 划 会 议 。 不 过 如 果 确 实 需要 马上 启动 Sprint， 不 妨 先 这 么 着 
吧 。 认 真 说 来 ， 只 有 这 么 点 儿 信息 就 开始 sprint， 我 还 从 来 没有 试 过 。 








优先 级 2: 经 团队 认可 、 要 添加 到 当前 sprint 中 的 故事 列表 。 
优先 级 3: ” sprint 中 每 个 故事 的 估算 值 。 
优先 级 4: ”sprint 中 每 个 故事 的 “如 何 演示 ”。 


优先 级 5: ”生产 率 和 资源 计算 ， 用 作 sprint 计 划 的 现实 核 仍 。 包 括 团 
队 成 员 的 名 单 及 每 个 人 的 承诺 《不 然 就 没 法 计算 生产 率 ) 。 


优先 级 6: 明确 每 日 例会 固定 举行 的 时 间 地 点 。 这 只 需要 花 几 分 
钟 ， 但 如 果 时 间 不 够 用 ，ScrumMaster 可 以 在 会 后 直接 定 下 来 ， 邮 件 通 
知 所 有 人 。 


优先 级 7: ”把 故事 拆 分 成 任务 。 这 个 拆 分 也 可 以 在 每 日 例会 上 做 ， 
不 过 这 会 稍稍 打 乱 sprint 的 流程 。 


技术 故事 


这 有 个 很 复杂 的 问题 : 技术 故事 。 或 者 叫 非 功能 性 条 目 ， 或 者 你 想 
叫 它 什么 都 行 。 





我 指 的 是 需要 完成 但 又 不 属于 可 交付 物 的 东西 ， 跟 任何 故事 都 没有 
直接 关联 ， 不 会 给 产品 负责 人 带 来 直接 的 价值 。 





我 们 称 之 为 “技术 故事 ”。 





示例 


四 ” 灾 装 持续 构建 服务 器 








口 为 什么 要 完成 它 ? 因为 它 会 节省 开发 人 员 的 大 量 时 间 ， 到 
迭代 结束 的 时 候 ， 集 成 也 不 太 容 易 出 现 重大 问题 。 


a 编写 系统 设计 概览 





口 为 什么 要 完成 它 ? 因 为 开发 人 员 营 第 会 瑟 记 系统 的 整体 设 
计 ， 写 出 与 之 不 一 致 的 代码 。 团 队 需 要 有 个 描述 整体 概 
况 的 文档 ， 保 证 每 个 人 对 设计 都 有 同样 的 理解 。 





e 重 构 DAO 层 


口 “ 为 什么 要 完成 它 ? 因为 DAO 层 代码 已 经 乱 成 一 团 了 。 混 
乱 带 来 了 本 可 以 避免 的 bug， 每 个 人 的 时 间 都 在 被 无 谓 地 
消耗 。 清 理 代码 可 以 节省 大 家 的 时 间 ， 提 高 系统 的 健壮 
性 。 


me 升级 Jira (bug 跟 踪 工 具 ) 


O 为 什么 要 完成 它 ? 当前 的 版 本 bug 狂 多 ， 又 很 慢 ， 升 级 以 
后 可 以 节省 大 家 时 间 。 





按照 一 般 的 观点 来 看 ， 这 些 算是 故事 吗 ? 或 者 是 一 些 跟 任何 故事 都 





没有 直接 关联 的 任务 ? 谁 来 给 它们 划分 优先 级 ?产品 负责 人 应 该 参与 其 
中 吗 ? 


我 们 尝试 过 各 种 处 理 方式 。 我 们 曾经 把 它们 跟 别 的 故事 一 样 ， 当 作 
第 一 等 的 故事 。 但 这 样 并 不 好 。 产 品 负 责 人 来 对 产品 backlog 划 分 优先 级 
的 时 候 ， 就 像 在 拿 苹果 跟 桔 子 作 对 比 一 样 。 实 际 上 ， 出 于 显而易见 的 原 
因 ， 技 术 故 事 音 利 会 因为 某 种 原因 给 设置 一 个 低 优 先 级 ， 例 如 :“ 嘿 ， 
兄 种 们 ， 我 知道 持续 构建 服务 器 很 重要 ， 不 过 让 我 们 先 来 完成 一 些 可 以 
市 来 收入 的 特性 吧 ， 然 后 再 来 弄 那 些 技术 上 的 东西 ， 行 不 ?” 





有 些 时 候 ， 产 品 负责 人 的 做 法 是 对 的 ， 但 这 只 是 少数 情况 。 我 们 得 
出 的 结论 是 ， 产 品 负责 人 往往 不 能 对 此 做 出 正确 的 权衡 。 所 以 我 们 采取 
了 下 面 这 些 做 法 。 


1. 试 着 避免 技术 故事 。 努 力 找 到 一 种 方式 ， 把 技术 故事 变 成 可 以 
衡量 业务 价值 的 普通 故事 。 这 样 有 助 于 产品 负责 人 做 出 正确 的 
权衡 。 


2. 如 果 无 法 把 技术 故事 转变 成 普通 故事 ， 那 就 看 看 这 项 工作 能 
能 当 作 另 一 个 故事 中 的 茶 个 任务 。 例 如 ,“ 重 构 DAO 层 ?可 以 作 
为 “编辑 用 户 ” 中 的 一 个 任务 ， 因 为 这 个 故事 会 涉及 到 DAO 层 。 


3. 如 果 以 上 二 者 都 不 管用 ， 那 吏 把 它 定 义 为 一 个 技术 故事 ， 用 忆 
外 一 个 单独 的 列表 来 存放 。 产 品 负 责 人 能 看 到 它 ， 但 是 不 能 多 
辑 它 。 用 “投入 程度 "和 * 预 佑 生产 率 ” 这 两 个 参数 来 跟 产品 负责 
人 协商 ， 从 sprint 里 拨 出 一 些 时 间 来 完成 这 些 技术 故事 。 





下 面 是 一 个 示例 (这 上段 对 话 跟 我 们 某 个 sprint 计 划 会 议 中 发 生 过 的 
一 幕 似曾相识 ) 。 


mA: “我 们 要 完成 一 些 内 部 的 技术 工作 。 也 许 要 从 我 们 的 时 
间 里 抽出 来 10%， 也 就 是 把 投入 程度 从 75% 降 低 到 65%， 你 看 
行 吗 ? * 


mw pinot A: “不 行 ! 我 们 没 那 个 时 间 了! ” 


m GIB: “中 ..…….. 那 看 看 上 一 个 Sprint 吧 。 (大 家 的 头 全 都 转向 了 
白板 上 的 生产 率 章 图 。) 我 们 估算 的 生产 率 是 80， 但 实际 才 有 
40， 没 错 吧 ? ” 


me 产品 负责 人 : “ 没 错 ! 所 以 我 们 没 时 间 干 那些 内 部 的 技术 活 
了 ! 我 们 需要 新 功能 ! ” 





m 团队: “We, BIE PARRA RA 就 是 ， 构 造 可 
以 测试 的 稳定 版 本 占用 了 太 多 时 间 。” 


E 产品 负责 人 : “ME, ABA Ia Ne? 


m 团队 : ”“ 唔 ， 如 果 我 们 不 做 后 什么 的 话 ， 生 产 率 还 会 继续 这 么 


四 产品 负责 人 : “WE, RAWH? ” 


m 团队 : “所 以 我 们 建议 在 这 个 sprint 里 抽出 大 概 10% 的 时 间 来 搭 
一 个 持续 构建 服务 器 ， 完 成 相关 的 一 些 事情 ， 这 样 就 不 会 再 受 
集成 的 折磨 。 接 下 来 ， 每 个 sprint 里 面 ， 我 们 的 生产 率 都 会 提 
高 至 少 20%! ” 





me 产品 负责 人 : “ 呵 ? 真 的 吗 ? 那 为 什么 上 个 sprint 我 们 没 这 么 


四 产品 负责 人 : ”“ 哦 ， 咽 .…... 那 好 吧 ， 这 主意 听 上 去 不 错 ， 开 始 





当然 ， 还 可 以 把 产品 负责 人 排除 在 外 ， 或 者 是 告诉 他 一 个 不 可 协商 
的 投入 程度 。 但 你 不 妨 先 尝试 一 下 ， 让 你 们 的 想法 达成 一 致 。 


如 果 产 品 负 贡 人 能 力 比 较 强 ， 也 能 听 进 别人 的 意见 〈 这 一 点 上 ， 我 
MIERES) ， 那 我 建议 你 最 好 还 是 尽量 让 他 知道 所 有 的 事情 ， 让 他 制 
定 一 切 工 作 的 优先 级 。 透 明 也 是 Scrum 的 核心 价值 ， 不 是 吗 ? 








bugik fe A ivs.” fm backlog 


这 个 问题 有 点 难 搞 。 ee ha oe A E) 不 过 你 仍 
要 一 个 bug 跟 踪 系 统 ， 这 时 Excel 就 无 条 了 。 我 们 用 的 是 Jira。 


那 我 们 怎么 把 Jira 上 的 难题 带 到 Sprint 计划 会 议 上 来 呢 ? 我 的 意思 


是 ， 如 果 无 视 这 些 难 题 ， 只 关心 故事 ， 这 可 没什么 好 处。 


我 们 试 过 下 面 几 种 办 法 。 


1. 产品 负责 人 打印 出 Jira 中 优先 级 最 高 的 一 些 条 目 ， 带 到 sprint 计 
划 会 议 中 ， 跟 其 他 故事 一 起 贴 到 墙 上 (因此 就 暗暗 地 指明 了 这 
些 难 题 相 对 其 他 故事 的 优先 级 ) 。 








2. 产品 负责 人 创建 一 些 指 向 Jira 条 目的 故事 。 例 如 “修复 那 几 个 后 
台 报 表 最 严重 的 bug， 序 号 是 Jira-124、Jira-126， 还 有 Jira- 
180”. 


3. 修复 bug 被 当 作 sprint 以 外 的 工作 ， 也 就 是 次 ， 团 队 会 保持 一 个 
足够 低 的 投入 程度 〈 例 如 50% ) ， 从 而 保证 他 们 有 时 间 来 修复 
bug。 然 后 我 们 就 可 以 简单 假设 ， 在 每 一 个 sprint 中 ， 团 队 都 会 
用 一 些 时 间 来 修复 Jira 上 报告 的 bug。 


4. 把 产品 backlog 放 到 Jira 上 (也 就 是 放弃 Excel) 。 把 bug 与 其 他 故 
事 同 每 看 待 。 


我 们 没有 发 现 哪 种 策略 最 适合 我 们 ， 实 际 来 看 ， 团 队 与 团队 、 


Sprint 与 Sprint 之 间 的 做 法 都 会 有 差异 。 不 过 我 还 是 倾 癌 于 使 用 第 一 种 方 


案 。 


既 简 单 ， 效果 又 好 。 


sprint 计 划 会 议 终 于 结束 了 


哇塞 ， 没 想到 这 一 章 会 这 么 长 ! 我 想 这 应 该 可 以 表示 出 我 的 个 人 观 
点 一 一 sprint 计 划 会 议 是 Scrum 中 最 重要 的 活动 。 在 这 里 投入 大 量 努 力 ， 
保证 它 顺 利 完成 ， 后 面 的 工作 束 会 轻松 很 多 。 








如 果 每 个 人 《上 所 有 的 团队 成 员 和 产品 负责 人 ) 离开 会 场 时 都 面 带 微 
笑 ， 第 二 天 醒 来 时 面市 微笑 ， 在 第 一 次 的 每 日 例会 上 面 带 微 突 ， 那 
sprint 计 划 会 议 就 是 成 功 的 。 


当然 ， 什 么 事情 都 有 可 能 出 现 问 题 ， 但 至 少 你 不 能 归咎 于 sprint 计 
划 : o) 














(1) 译 者 注 : 心理 学 家 米 哈里 教授 (Mihaly Csikszentmihalyi) 将 流 (flow) 定义 为 一 种 将 个 
人 和 精神 力 完 全 投注 在 某 种 活动 上 的 感觉 ， 流 产生 时 同时 会 有 高 度 的 兴奋 及 充实 感 。 





























第 5 革 ”我 们 怎样 让 列 人 了 解 我 们 


的 Sprint 








我 们 要 让 整个 公司 了 解 我 们 在 做 些 什么 ， 这 件 事 情 至 关 重 要 。 人 否则 
其 他 人 融会 发 出 抱 急 ， 甚 或 对 我 们 的 工作 做 出 腾 断 。 


我 们 为 此 使 用 如 下 图 所 示 的 “sprint 信 息 页 ”。 


Sprint goal 
- Beta-ready release! 


Sprint backlog (estimates in parenthesis) 
- Deposit (3) 

- Migration tool (8) 

- Backoffice login (5) 

- Backoffice user admin (5) 


Estimated velocity: 21 


Schedule 

- Sprint period: 2006-11-06 to 2006-11-24 

- Daily scrum: 9:30 — 9:45, in the team room 

- Sprint demo: 2006-11-24, 13:00, in the cafeteria 


Team 

- Jim 

- Erica (scrum master) 
- Tom (75%) 

- Eva 

- John 





有 时 我 们 也 会 包括 每 个 故事 该 如 何 演示 。 


sprint 计 划 会 议 一 结束 ，ScrumMaster 就 创建 这 个 页 面 ， 把 它 放 到 
wiki 上， 给 整个 公司 发 一 封 “ 垃 圾 ”邮件 。 见 下 图 。 


Subject: Jackass sprint 15 started 


Hi all! The Jackass team has now started sprint 
15. Our goal is to demonstrate a beta-ready 
release on nov 24. 


See the sprint info page for details: 
http://wiki.mycompany.com/jackass/sprint15 











我 们 在 wiki 上 还 有 如 下 图 所 示 的 “dashboard” 页 面 ， 链 接 到 所 有 正在 
进行 的 sprint。 


Corporate Dashboard 


Ongoing sprints 


e Team X sprint 15 
Team Y sprint 12 
Team Z sprint 1 





此 外 ，ScrumMaster 还 会 把 Sprint 信息 页 打印 出 来 ， 贴 到 团队 房间 外 
面 的 场 上 。 路 过 的 每 个 人 都 可 以 阅读 这 张 纸 ， 了 解 这 个 团队 所 做 的 事 
情 。 因 为 其 中 还 包括 了 每 日 例会 的 时 间 地 点 ， 所 以 他 也 能 知道 到 哪里 去 
了 解 更 多 信息 。 


sprint 接 近 尾 声 时 ，ScrumMaster 会 把 即将 来 临 的 演示 告知 每 个 人 。 


Subject: Jackass sprint demo tomorrow at 13:00 in the cafeteria. 


Hi all! You are welcome to attend our sprint demo at 13:00 in 
the cafeteria tomorrow (friday). We will demonstrate a 
beta-ready release. 


See the sprint info page for details: 
http://wiki.mycompany.com/jackass/sprint15 








有 了 这 一 切 以 后 ， 就 没 人 还 能 找 借口 次 不 知道 ”你 们 的 工作 状态 
Ty 


BE ”我 们 怎样 编写 sprint 
backlog 


sprint backlog 的 形式 
任务 板 怎样 发 挥 作用 
JS PRG t ACHE VE H 


任务 板 警 示 标 记 





你 已 经 走 了 这 么 远 了 ? M, FER. 


现在 我 们 已 经 完成 了 sprint 计 划 会 议 ， 整 个 世界 都 了 解 了 我 们 下 一 
个 烂 烟 生 辉 的 sprint。ScrumMaster 现 在 应 该 创建 sprint backlog 了 。 它 应 
该 在 sprint 计 划 会 议 之 后 ， 第 一 次 每 日 例会 之 前 完成 。 


sprint backlog 的 形式 


我 们 曾经 尝试 过 用 多 种 形式 来 保存 sprint backlog， 包 括 Jira、 
Excel， 还 有 挂 在 墙 上 的 任务 板 。 开 始 我 们 主要 使 用 Excel， 有 很 多 公开 
的 Excel 模 板 可 以 用 来 管理 sprint ”backlog 一 一 包括 自动 生成 的 燃 尽 图 等 
等 。 在 如 何 改 良 基 于 Excel 的 sprint backlog 方 面 ， 我 有 很 多 想法 ， 但 此 处 
暂且 不 提 ， 我 也 不 会 在 这 里 举例 。 





下 面 要 仔细 摘 述 的 ， 是 我 们 发 现 管理 sprint ”backlog 最 有 效 的 形式 
一 一 挂 在 墙 上 的 任务 板 ! 


找 一 面 尚 未 使 用 或 者 充满 无 用 信息 (如 公司 logo、 陈 旧 图 表 或 者 丑 
陋 的 涂鸦 ) 的 大 墙 。 清 理 场 辟 《〈 除 非 不 得 已 才 去 请 求 别人 许可 ) o Eh 
上 贴 上 一 张 很 大 很 大 的 纸 〈 至 少 2x2 平 方 米 ， 大 团队 需要 3x2 平 方 米 ) 。 
然后 如 下 这 般 规划 。 





你 当然 也 可 以 用 白板 。 不 过 那 多 少 有 扣 浪 费 。 可 能 的 话 ， 还 是 把 日 
板 省 下 来 画 设计 和 草图， 用 没有 挂 白 板 的 墙 做 任务 板 。 








注意 一 一 如 果 你 用 贴纸 来 记录 任务 ， 别 迄 了 用 真正 的 胶带 把 它们 粘 
好 ， 人 否则 有 一 天 你 会 发 现 所 有 的 贴纸 都 在 地 上 堆 成 一 扒 。 


任务 板 怎 样 发 挥 作用 
任务 板 的 作用 如 下 图 所 示 。 


First all activity post-its wander this way 





当然 ， 也 可 以 另外 添上 许多 列 ， 比 如 “等 待 集成 测试 ”， 或 者 “已 取 
消 ”。 但 是 在 把 这 一 切 搞 复 杂 之 前 ， 请 试 着 仔细 考虑 考虑 ， 你 要 添上 去 
的 那 一 列 真 的 ， 真 的 是 没 它 不 行 吗 ? 


我 发 现在 处 理 这 种 类 型 的 事情 时 , “简单 性 ”会 及 挥 极 大 的 作用 ; 所 
以 除非 不 这 样 做 会 付出 极 大 代价 ， 我 才 愿 意 让 事情 变 得 更 加 复杂 。 











例 1 一 一 首次 每 日 Scrum 之 后 


在 痛 次 每 日 例会 以 后 ， 任 务 板 可 能 会 变 成 下 图 这 样 。 


你 可 以 看 到 ， 有 三 个 任务 已 经 被 “checked out”， 团 队 今 天 将 处 理 这 
些 条 目的 工作 。 

在 大 团队 中 ， 有 了 时 某 个 任务 会 一 直 停 留 在 “checked out” 状 态 ， 因 为 
己 经 没 人 记得 是 谁 认 领 了 这 个 任务 。 要 是 这 种 情况 一 再 发 生 ， 他 们 就 
会 在 任务 上 加 上 标签 ， 记 录 谁 check out 了 这 个 任务 。 





例 2 一 一 几 天 以 后 


儿 天 以 后 ， 任 务 板 可 能 会 如 下 图 所 示 。 





你 可 以 看 到 ， 我 们 已 经 完成 了 “DEPOSIT” 这 个 故事 ( 它 已 经 被 签 入 
了 源 代 码 人 仓库， 经 过 了 测试 、 重 构 等 等 步 又) 。“MIGRATION 
TOOL” 只 完成 了 一 部 分 ，“BACKOFFICE LOGIN” 刚 刚 开 
iA» “BACKOFFICE USER ADMIN” 还 没有 开始 。 





我 们 有 3 个 未 经 过 计划 的 条 目 ， 放 在 任务 板 的 右 下 角 。 进 行 sprint 回 
顾 的 时 候 应 当 记 住 这 一 点 。 


下 图 是 一 个 真实 的 sprint backlog。 这 里 sprint 已 经 接近 结尾 。 在 
sprint 的 进展 中 ， 这 张 表 变 得 相当 乱 ， 不 过 因为 这 个 状态 很 短 ， 所 以 没 
太 大 关系 。 每 个 新 的 sprint 局 动 后 ， 我 们 都 会 创建 一 个 全 新 的 、 干 滔 的 
sprint backlog. 





燃 斥 图 如 何 友 挥 作用 
让 我 们 把 目光 投向 燃 尽 图 。 
下 图 包含 的 信息 如 下 。 


m ” Sprint 的 第 一 天 ，8 月 1 号 ， 团 队 估算 出 剩 下 70 个 故事 点 要 完成 。 
这 实际 上 就 是 整个 sprint 的 估算 生产 率 。 


m 在 8 月 16 号 ， 团 队 估算 出 还 剩 下 15 个 故事 点 的 任务 要 做 。 跟 表示 
趋势 的 虚线 相对 比 ， 团 队 的 工作 状态 还 是 差不多 沿 着 正轨 的 。 
按照 这 个 速度 ， 他 们 能 在 sprint 结 束 时 完成 所 有 任务 。 








BURNOOWN 


ESTIMATED WORK 
REMAINING 
(5Togy POINTS) 








我 们 没 把 周末 放 到 表示 时 间 的 X 轴 上 ， 因 为 很 少 有 人 会 在 周末 干 活 
儿 。 我 们 曾经 把 周末 也 算 了 进来 ， 但 是 这 两 天 的 曲线 是 平 的 ， 看 上 去 残 


像 警 告 sprint 中 出 现 了 问题 ， 这 就 让 人 看 着 不 严 了 。 


任务 板 警示 标记 


在 任务 板 上 匆匆 一 管 ， 就 可 以 大 致 了 解 到 sprint 的 进展 状态 。 
ScrumMaster 尺 当 确 保 团 队 会 对 下 图 所 示 的 这 些 警 示 标 记 做 出 反应 。 


OUCH! Need to 
remove some 


BURNDOWN backlog items from 


the sprint 





Need to add some 









OUCH! Team is doing stuff in 
the wrong order, and neglecting 
the top-priority items! 






IOUCHI! Unplanned items 
are killing the sprint! 





WE TAKE RPE TT ER bar Ve 





在 这 种 模型 中 ， 如 采 必 须 跟踪 的 话 ， 那 我 能 提供 的 最 佳 方式 ， 就 是 
每 天 给 任务 板 担 一 张 数码 照片 。 我 有 时 也 这 样 干 ， 但 一 直 没 用 到 这 些 照 
Fs 


如 果 你 确实 需要 跟踪 任务 进度 ， 任 务 板 这 种 解决 方案 可 能 就 不 太 适 


合 你 。 


不 过 我 建议 你 应 该 试 着 去 评估 一 下 ， 对 sprint 进 行 细节 跟踪 能 带 给 
你 多 大 价值 。sprint 完 成 以 后 ， 可 以 工作 的 代码 已 被 交付 ， 文 档 也 被 
check in， 那 还 有 谁 会 真 的 关心 sprint 的 第 5 天 完成 了 多 少 故 事 呢 ?又 有 谁 
会 真 的 关心 “为 deposit 编 写 失 败 测 试 * 曾 经 的 估算 量 是 多 少 ? 


天 数 估算 vs. 小 时 估算 


在 讲述 Scrum 的 书 和 文章 中 ， 大 多 数 都 是 用 小 时 而 不 是 天 数 来 估算 
时 间 。 我 们 也 这 样 干 过 。 我 们 的 通用 方程 为 1 个 有 效 的 人 -天 三 6 个 有 效 
的 人 -小 时 。 


现在 我 们 已 经 不 这 么 干 了 ， 至 少 在 大 部 分 团队 中 如 此 。 原 因 如 下 。 


四 ”人 -小 时 的 粒度 太 细 了 ， 它 会 导致 太 多 小 到 1 一 2 个 小 时 的 任务 出 
现 ， 然 后 束 会 引 友 微观 管理 。 





四 ”最 后 发 现实 际 上 每 个 人 还 是 按照 人 -天 的 方式 来 思考 ， 只 是 在 填 
写 数据 时 把 它 乘 6 就 得 到 了 人 -小 时 。“ 嗯 .…… 这 个 任务 要 人 花 一 
天 。 莪 对 ， 我 要 写 小 时 数 ， 那 我 就 写 6 小 时 好 了 。?” 


四 ”两 种 不 同 的 单位 会 导致 混乱 。“ 这 个 估算 的 单位 是 啥 ? 人 -天 还 
是 人 -小 时 ? ” 


第 7 草 ”我 们 怎样 布 征 团队 房间 


时 ”让 团队 坐 在 一 起 





国 。 让 产品 负责 人 无 路 可 走 


m 让 经 理 和 教练 无 路 可 走 








我 曾 发 现 这 样 一 个 事实 : 大 多 数 最 有 趣 最 有 价值 的 设计 讨论 ， 都 是 
在 任务 板 前 面 自然 而 然 地 发 生 的 ， 所 以 我 们 试 着 把 这 个 区 域 布置 成 一 个 
明显 的 “设计 角 ”( 见 下 图 ) 。 





设计 墙 (大 的 白板 ) 


anon 公用 计算 机 
v 
E 
5 
大 量 足 以 站 =e 
Ww, WE, S 
指 指点 点 ， A 
做 手势 的 空间 => 
$% 
5 


KEKRAH. BRERA, PY aita A E 
MMA, Aa BARAAT A ASAR RARE R AS 
下 ， 还 有 什么 方式 能 比 这 更 有 效 呢 ? (如 果 你 运气 不 错 、 拥 有 持续 构建 
的 话 。 参 见 第 13 章 “我 们 怎样 结合 使 用 Scrum 和 XP”。 ) 








“设计 墙 ? 只 是 一 块 大 和 白板， 上面 画 着 最 重要 的 设计 和 草图， 还 有 打印 
出 来 的 、 最 重要 的 设计 文档 〈 顺 序 图 ，GUI 原 型 ， 领 域 模型 ， 等 等 ) 。 





下 图 为 在 上 述 角落 中 进行 的 每 日 例会 。 





iA 
A: a) g 
i 

A 


R... TARR RATES, RRBREA, MEANE 
持 说 它 是 真实 情况 的 反映 : 0) 


让 团队 坐 在 一 起 
在 安排 座位 、 布 置 桌 椅 这 方面 ， 有 一 件 事情 怎么 强调 也 不 为 过 。 
让 团队 坐 在 一 起 ! 


说 得 更 清楚 一 点 ， 我 说 的 是 


让 团队 坐 在 一 起 ! 


大 家 都 懒得 动 。 至 少 我 工作 的 地 方 是 这 样 的。 他 们 不 想 收 拾 起 目 己 
的 零 俯 儿 、 拔 下 计算 机 电源 、 把 东西 都 挪 到 新 的 电脑 时 上 ， 然 后 把 一 切 
再 插 回 去 。 挪 的 距离 越 短 ， 这 种 抵触 情绪 就 越 强 烈 。“ 老 大 ， 干 啉 呢 ， 
动 这 5 米 有 了 喻 用 ? ” 

















但 是 为 了 把 Scrum 团 队 弄 得 上 档次 一 些 ， 在 这 方面 没有 其 他 选择 。 
一 定 要 让 他 们 坐 到 一 起 。 即 使 你 不 得 不 私下 里 威胁 每 一 个 人 ， 给 他 们 清 
理 零 和 俯 ， 把 老 位 子 收拾 利索 。 如 果 空 间 不 够 ， 那 就 找 个 地 方 创 造 空 间 。 
就 算 把 团队 搬 到 地 下 室 里 面 去 也 在 所 不 惜 。 把 桌子 拼 到 一 起 ， 贿 赂 办 公 
室 管理 员 ， 竭 尽 所 能 。 只 要 能 让 他 们 坐 到 一 起 。 

只 要 让 他 们 坐 到 一 起 ， 就 会 有 立竿见影 的 成 效 。 过 上 一 个 sprint， 
团队 就 会 认为 挪 到 一 起 是 绝妙 的 主意 《从 我 的 个 人 经 验 来 看 ， 你 的 团队 
也 有 可 能 会 固执 地 不 承认 这 一 点 ) 。 


那 怎 么 才 算 坐 到 “一 起 ”? 桌子 该 怎么 摆 ? 呢 ， 我 在 这 方面 没 太 多 建 
议 。 而 且 就 算 我 有 ， 狼 但 大 多 数 团队 也 疫 有 奢侈 到 可 以 决定 怎么 摆 放 果 





子 。 工 作 空 间 中 总 是 有 太 多 物理 限制 
中 间 的 大 型 自动 售 货 机 ， 等 等 。 





隔壁 的 团队 、 厕 所 的 门 、 屋 子 





“一 起 ?具有 以 下 含义 。 


e 互相 听 到 所 有 人 都 可 以 彼此 交谈 ， 不 必 大 声 喊 ， 不 必 离 开 座 


位 。 





e ”互相 看 到 所 有 人 部 可 以 看 到 彼此 ， 都 能 看 到 任务 板 
非得 近 到 可 以 看 清楚 内 容 ， 但 至 少 可 以 看 到 个 大 概 。 


不 用 





mE 隔离 如 条 你 们 整个 团队 突然 站 起 来 ， 目 发 形成 一 个 激烈 的 设 
计 讨 论 ， 团 队 外 的 任何 人 都 不 会 被 打扰 到 。 反 之 亦 然 。 











“隔离 ”并 不 是 意味 着 这 个 团队 需要 被 完全 隔离 起 来 。 在 一 个 格子 间 
的 环境 中 ， 如 采 你 的 团队 拥有 目 己 的 格子 ， 而 且 隔 间 的 墙 足 够 大 ， 可 以 
屏蔽 增 内 外 的 大 多 数 噪音 ， 这 也 就 足够 了 。 





如 果 是 分 布 式 团队 怎么 办 ? We, MWS. BRAY ERRA 
手段 来 减少 分 布 式 带 来 的 损害 吧 一 一 比如 视频 会 议 、 网 络 摄像 头 、 桌 面 


er AEA 
共享 工具 ， i a 














让 产品 负责 人 无 路 可 走 


产品 负责 人 应 该 离 团 队 很 近 ， 既 方便 团队 成 员 走 过 来 讨论 问题 ， 他 

也 能 随时 距 到 任务 板 前 面 去 。 但 是 他 不 应 该 跟 团 队 坐 在 一 起 。 为 什么 ? 

i a i 团队 也 无 法 “凝聚 "成 整 
体 〈 即 达到 关系 基 密 、 目 组 织 、 具 有 超 高 生产 力 的 状态 ) 。 











说 实话 ， 这 全 是 我 目 己 的 猜测 。 因 为 从 来 没有 磺 到 过 产品 负责 人 跟 
团队 坐 到 一 起 的 情况 ， 所 以 上 面 的 说 法 也 没有 实际 根据 。 只 是 一 种 直观 
的 感觉 ， 也 有 从 其 他 ScrumMaster 那 里 的 道听途说 。 





练 .. 


换 、 


想 ， 


让 经 理 和 教练 无 路 可 走 


这 一 刻 ， 手 指 的 移动 变 得 格外 艰难 ， 因 为 我 既是 经 理 ， 又 是 教 


尽 可 能 和 团队 紧密 工作 ， 这 是 我 的 职责 。 我 组 建 团队 、 在 团队 间 切 
跟 人 结对 编程 、 培 训 ScrumMaster、 组 织 sprint 计 划 会 议 ..….... 事 后 想 
大 多 数 人 都 认为 这 是 个 好 事情 ”， 因 为 我 在 敏捷 软件 开发 方面 具有 


相当 的 经 验 。 


AR 
我 管 


但 是 ， 另 一 方面 ， 我 同时 〈《《 星 球 大 战 》 中 黑 武 士 的 出 场 音 乐 响 
也 是 开发 主管 ， 从 行政 上 担任 着 经 理 职务 。 于 是 每 次 我 来 到 团队 中 





， 他 们 的 目 组 织 性 就 会 降低 。"“ 见 鬼 ， 老 大 来 了 ， 他 可 能 有 很 多 想 
， 告 诉 我 们 应 该 干 喻 ， 谁 应 该 去 做 什么 。 让 他 说 吧 。” 


我 是 这 么 看 的 ， 如 宁 你 是 Scrum 教 练 〈 或 许 同时 也 是 经 理 ) ， 就 应 
可 能 贴近 团队 。 但 不 久 以 后 ， 瓯 离开 他 们 ， 让 他 们 凝聚 在 一 起 ， 目 
理 。 然 后 每 隔 一 段 时 间 (A BAM) ， 就 去 参加 一 次 他 们 的 


sprint 演 示 ， 看 看 任务 板 ， 听 听 晨 会 。 如 果 发 现 有 可 以 改进 的 地 方 ， 整 
把 ScrumMaster 搜 出 来 指导 他 。 但 是 不 要 在 团队 面前 这 样 干 。 男 外 ， 如 
末 团 队 足 够 信任 你 ， 他 们 不 会 看 见 你 就 有 上 嘴巴 ， 那 去 参加 他 们 的 
Sprint 回顾 也 是 个 好 主意 〈 人 参见 第 10 章 “我 们 怎样 做 Sprint 回顾 ”) 。 











对 于 运转 展 好 的 Scrum 团 队 ， 只 需要 保证 他 们 可 以 得 到 一 切 所 需 的 


东西 ， 然 后 就 可 以 任 他 们 自由 发 挥 了 除了 sprint 演 示 以 外 〉。 


第 8 章 ”我 们 怎样 进行 每 日 例会 


四 ”我 们 怎样 更 新 任务 板 
四 ”处 理 迟 到 的 家 伙 


E ”处理 “我 不 知道 今天 干什么 ”的 情况 


我 们 的 每 日 例会 与 书本 上 介绍 的 几乎 没 喻 两 样 。 它 们 每 天 都 会 在 同 
一 个 地 方 、 同 一 个 时 间 进 行 。 最 开始 ， 我 们 都 是 去 一 个 单独 的 房间 做 
sprint 计 划 ( 当 我 们 还 是 用 电子 版 sprint backlog 的 时 候 ) ， 不 过 现在 我 们 
都 是 在 团队 房间 里 、 任 务 板 的 前 面 进行 每 日 例会 。 没 什么 能 比 它 效 果 更 
Uf. 


我 们 一 般 都 是 开 站 立会 议 ， 以 防止 持续 时 间 超 过 15 分 钟 。 


我 们 怎样 更 新 任务 板 


一 般 我 们 都 是 在 每 日 例会 的 时 候 更 新 任务 板 。 每 个 人 都会 一 边 描述 
昨天 已 经 做 的 事情 和 今天 要 做 的 事情 ， 一 边 移 动 任务 板 上 对 应 的 即时 
贴 。 如 果 他 讲 的 是 一 个 未 经 计划 的 条 目 ， 那 他 就 重新 写 一 张 即 时 贴 ， 贴 
到 板 上 。 如 果 他 更 新 了 时 间 估 算 ， 那 束 在 即时 巾 上 写 上 新 的 时 间 ， 把 旧 
RHE FED 。 有 了 时候 ScrumMaster 会 在 大 家 讲述 各 自 工作 的 同时 
做 这 件 事情 。 








有 些 团 队 会 规定 每 个 人 都 要 在 会 议 开 始 前 ”更 新 任务 板 。 这 个 做 法 





也 不 错 。 你 只 要 订 好 规则 ， 坚 持 执 行 就 行 。 


但 无 论 你 的 sprint backlog 是 什么 形式 ， 都 要 尽力 让 整个 团队 参与 到 
保持 sprint backlog 及 时 更 新 的 工作 中 来 。 我 们 曾经 试 过 让 ScrumMaster 自 
己 维护 sprint backlog， 他 就 不 得 不 每 天 都 去 询问 大 家 各 自 剩 余 的 工作 佑 
算 时 间 。 这 种 做 法 有 以 下 缺点 。 





图。 ScrumMaster 把 太 多 时 间 用 在 管理 工作 上 ， 而 不 是 为 团队 提供 文 
持 ， 消 除 他 们 的 障碍 。 


m 因为 团队 成 员 不 再 关心 Sprint backlog， 所 以 他 们 惑 意 识 不 到 
Sprint 的 状态 。 缺 少 反 馈 ， 团 队 整 体 的 敏捷 度 和 精力 的 集中 程 


度 都 会 下 降 。 





如 果 sprint backlog 设 计 得 很 好 ， 那 每 个 人 都 应 该 很 容易 修改 它 。 


每 日 例会 一 结束 ， 就 要 有 人 算出 剩余 工作 的 时 间 估 算 之 和 《上 自然 ， 
那些 被 放 在 “done” 一 栏 中 的 就 不 用 算 了 ) ， 在 Sprint 燃 尽 图 上 男 上 一 个 新 
的 点 。 


Mb SHIR BY A Ae tk 


ALE aes MF ERRE. WAR ORHE T, BERRA — IE, tes 
须 往 里 面 投入 定额 的 钱 。 没 有 人 关心 迟到 的 理由 。 即 使 你 提前 打 电 话 声 
WI ZR BY, ARAB TH aK 





除非 你 有 很 好 的 理由 ， 比 如 预约 了 看 病 ， 或 者 是 举办 你 自己 的 婚礼 


FY 
等 。 


I 


v 


FF Pee LA PY PAF. RASS PERK, FIR EEO 
KIR: o) 

IPHAN ASE MER A ATA E B BIA A a Be ie E 
度 。 有 些 团队 就 根本 不 需要 。 


处 理 “ 我 不 知道 今天 干什么 ”的 情况 


有 了 时候， 有 人 会 说 “我 昨天 干 了 这 个 、 这 个 和 这 个 ， 但 是 今天 根本 
不 知道 该 干什么 。” 这 种 情况 并 不 少见 。 那 该 怎么 办 呢 ? 


让 我 们 假设 Joe 和 Lisa 两 个 人 都 不 知道 今天 该 干什么 。 


如 果 我 是 他 们 的 ScrumMaster， 我 会 让 大 家 继续 讲 下 去 ， 只 是 先 标 
记 一 下 哪些 人 没有 事情 做 。 所 有 人 都 讲 完 以 后 ， 我 会 跟 团 队 一 起 从 上 到 
下 裔 历任 务 板 ， 检 查 是 否 所 有 条 目 都 已 同步 ， 保 证 所 有 人 都 清楚 每 个 条 
目的 含义 ， 等 等 。 然 后 请 人 添加 更 多 的 即时 贴 。 接 下 来 我 就 会 对 觉得 自 
SAAN At, “我 们 已 经 过 了 一 过 任务 板 ， 你 们 现在 对 今天 要 做 
的 事情 有 想法 了 么 ?” 希 望 他 们 有 点 儿 概念 了 。 








如 果 他 们 还 不 知道 该 干什么 ， 我 会 考虑 他 们 是 不 是 可 以 去 跟 其 他 人 
结对 编程 。 假 设 Niklas 今 天 要 实现 后 人 台 用 户 管理 的 GUI， 那 我 束 会 有 礼 
貌 地 建议 Joe 或 者 Lisa 去 跟 Niklas 结 对 。 这 种 做 法 通常 都 见效 。 

要 是 还 不 行 ， 那 我 束 会 像 下 面 这 样 干 。 


ScrumMaster: “好 ， 下 面 谁 来 给 我 们 演示 一 下 这 个 beta 版 的 发 
布 ? ”( 假 定 这 就 是 当前 的 sprint 目 标 ) 








Team (ERDE, RFV) 
ScrumMaster: “我 们 还 没完 成 ? ” 


Team: “ 咽 ...... 没 有 。” 


ScrumMaster: “我 靠 ! 为 啥 还 没 干 完 ? 还 剩 哪些 任务 ? ” 


Team: “我 们 到 现在 为 止 还 没有 测试 服务 器 ， 而 且 构 建 脚本 也 出 了 


问题 。” 


Le “ 啊 蛤 ! ”( 同 墙 上 增加 了 两 张贴 纸 。〉“Joe 和 
Lisa， 你 们 今天 能 帮 我 们 做 点 什么 呢 ?” 


Joe: “ 咖 .……. 我 可 以 试 着 四 处 找 找 测试 服务 器 。” 
Lisa: “.……. 我 可 以 试 着 修复 构建 脚本 。” 


如 采 你 很 笠 运 的 话 ， 有 些 人 会 出 来 把 beta 发 布 版 演示 给 你 看 。 那 就 
太 好 了 ! 你 已 经 达成 了 sprint 目 标 。 但 是 如 果 这 时 sprint 只 进行 了 一 半 
呢 ? 很 简单 。 先 就 已 完成 的 工作 加 他 们 表示 一 下 祝贺 ， 然 后 从 任务 板 右 
下 角 的 “Next”* 区 域 中 拿 出 一 两 个 故事 ， 放 到 左边 的 “not checked out” 列 
中 。 接 下 来 重新 进行 每 日 例会 。 告 诉 产品 负责 人 一 声 ， 你 已 经 把 一 些 条 
目 加 进 了 sprint。 





但 是 如 果 团 队 还 没有 达成 日 标 ， 而 且 Joe 和 Lisa 还 就 是 不 此 做 些 有 用 
的 工作 ， 那 义 该 怎么 办 ? 一 般 我 会 尝试 下 面 的 某 种 策略 (这 些 都 不 怎么 
让 人 愉快 ， 但 已 经 是 无 可 奈何 之 计 了 ) o 








E ASENA “如 果 你 不 知道 怎么 帮助 团队 ， 我 建议 你 还 是 回 
家 去 ， 或 者 看 书 ， 或 者 怎么 都 行 。 要 不 也 可 以 找 个 地 方 坐 下 ， 
等 别人 需要 帮忙 的 时 候 你 就 过 去 。” 











m 和 守旧 式 做 法 简单 给 他 们 分 配 个 任务 了 事 。 


e 施加 同事 压力 的 做 法 对 他 们 说 ，“Joe， 还 有 Lisa， 你 们 两 个 





可 以 放松 把， 我 们 会 站 在 这 里 慢 慢 等 ， 直 到 你 们 找到 帮助 我 们 
完成 目标 的 事情 为 止 。” 


m 奴役 式 做 法 ”对 他 们 说 , “你们 今天 可 以 给 大 伙 儿 干 点 杂 活 。 
倒 咖 啡 ， 做 按摩 ， 清 理 垃 圾 ， 做 午饭 ， 一 切 一 切 大 家 今天 让 你 
们 做 的 事情 。” 你 会 惊讶 地 发 现 Joe 和 Lisa 立 马 就 能 找 出 有 用 的 
技术 任务 : o) 








如 宁 一 个 人 第 币 盘 得 你 要 这 样 做 ， 那 就 应 该 考虑 是 不 是 把 他 单独 找 
出 来 做 辅导 。 倘 耕 问 题 依然 存在 ， 你 就 需要 衡量 一 下 这 个 人 对 于 团队 的 
HEE PE 





如 琳 他 不 是 KER, WATE TE MOR BAP IE - 


第 9 章 ”我 们 怎样 进行 Sprint 泗 示 


四 ”为 什么 我 们 坚持 所 有 的 Sprint 都 结束 于 演示 
四 ”Sprint 演示 检查 列表 


四 ”处理 “无 法 演示 ”的 工作 


Sprint 演示 〈 有 人 也 叫 它 Sprint 回顾) 是 Scrum 中 很 重要 的 一 环 ， 
党 为 人 们 低估 。 





“ 哦 ， 我 们 真 的 必须 做 演示 么 ? 没 喻 好 东西 能 展示 的 ! ” 
“我 们 没 时 间 准 备 &% 旷 的 演示 ! ” 


“我 没 时 间 参 加 其 他 团队 的 演示 ! ” 


却 


为 什么 我 们 坚持 所 有 的 sprint 都 结束 于 演示 

一 次 做 得 不 错 的 演示 ， 即 使 看 上 去 很 一 般 ， 也 会 带 来 深远 的 影响 。 
m ”团队 的 成 果 得 到 认可 。 他 们 会 感觉 很 好 。 

a ”其 他 人 可 以 了 解 你 的 团队 在 做 些 什么 。 

= 演示 可 以 吸引 相关 干系 人 的 注意 ， 并 得 到 重要 反馈 


四 ”演示 是 (或 者 说 应 该 是 ) 一 种 社会 活动 ， 不 同 的 团队 可 以 在 这 
里 相互 交流 ， 讨 论 各 目的 工作 。 这 很 有 意义 。 


四 ”做 演示 会 迫使 团队 真正 完成 一 些 工 作 ， 进 行 发 布 “ 即 使 是 只 在 
测试 环境 中 ) 。 如 果 没 有 演示 ， 我 们 就 会 总 是 得 到 些 99%% 完 成 
的 工作 。 有 了 演示 以 后 ， 也 许 我 们 完成 的 事情 会 变 少 ， 但 它们 
古 真 正 完成 ”的 。 这 【在 我 们 的 梁 例 中 〉 比 得 到 一 堆 貌 似 完成 
的 工作 要 好 得 多 ， 而 且 后 者 还 会 污染 下 一 个 sprint。 





如 果 一 个 团队 或 多 或 少 是 被 逼 着 做 演示 的 ， 尤 其 是 他 们 实际 没有 完 
成 多 少 工 作 的 状况 下 ， 演 示 就 会 变 得 令 人 乾 罚 。 团 队 在 做 演示 的 时 候 会 
结 结巴 巴 ， 之 后 的 掌声 也 会 显得 勉 勉 强 强 。 有 人 会 为 团队 感到 有 点 儿 难 
过 ， 也 有 人 感到 很 不 爽 ， 因 为 他 觉得 宝贵 时 间 被 浪费 在 了 一 场 很 烂 的 演 
Es 








这 会 伤害 一 些 人 。 但 它 是 否 口 展 药 。 等 到 下 一 个 sprint， 这 个 团队 
就 会 真得 试 着 做 完 一 些 事 情 ! 他 们 会 想 :“ 也 许 我 们 下 个 sprint 可 以 只 沉 
示 2 个 功能 ， 而 不 是 5 个 。 但 这 次 这 些 该 死 的 功能 一 定 会 正常 工作 ! ? 团 
队 知 道 这 次 无 论 如 何 他 们 也 要 进行 演示 ， 一 些 真正 有 用 的 东西 被 演示 出 








来 的 机 会 就 会 大 很 多 。 这 种 情况 我 已 经 目睹 很 多 次 了 。 





sprint 演 示 检 得 列 表 


m ”确保 清晰 闻 述 了 sprint 上 有 目标。 如果 在 演示 上 有 些 人 对 产品 一 无 所 
知 ， 那 就 花 上 几 分 钟 来 进行 描述 。 

m ”不 要 花 太 多 时 间 准 备 演 示 ， 尤 其 是 不 要 做 花 里 胡 哨 的 演讲 。 把 
那些 玩意 儿 扔 一 边 去 ， 集 中 精力 演示 可 以 实际 工作 的 代码 。 

外” 方 奏 要 快 ， 也 就 是 说 要 把 准备 的 精力 放 在 保持 演示 的 快 节 奏 
上 ， 而 不 是 让 它 看 上 去 好 看 。 

m 让 演示 关注 于 业务 层次 ， 不 要 管 技术 细节 。 注 意 力 放 在 “我 们 做 
了 什么 >， 而 不 是 “我 们 怎么 做 的 ”。 





m 可 能 的 话 ， 让 观众 上 自己 试 一 下 产品 。 

四 ”个 要 演示 一 大 堆 细 碎 的 bug 修 复 和 微不足道 的 特性 。 你 可 以 提 到 
一 些 ,， 但 是 不 要 演示 ， 因 为 它们 通常 会 花 很 长 时 间 ， 而 且 会 分 
散 大 家 的 注意 力 ， 让 他 们 不 能 关注 更 加 重要 的 故事 。 











处 理 “ 无 法 演示 ”的 工作 


团队 成 员 “我 不 打算 演示 这 个 条 目 ， 因 为 它 没 法 被 演示 。 这 个 故 
事 是 “提高 系统 的 可 扩展 性 ， 能 够 容纳 10000 个 用 户 的 并 发 请 求 :。 我 豁 出 
命 去 也 没 法 邀请 10000 个 用 户 同 时 来 做 演示 ， 不 是 吗 ? ” 


ScrumMaster: “和 那 你 做 完了 吗 ? ” 
团队 成 员 : “当然 。” 
ScrumMaster: “你 怎么 知道 昵 ? ” 


团队 成 员 “我 在 性 能 测试 环境 中 搭 好 了 系统 ， 启 动 8 个 负载 服务 
at, FFP ARS Min.” 








ScrumMaster: “但 是 你 有 没有 迹象 可 以 表明 系统 能 够 处 理 10000 个 
用 户 昵 ? ” 


团队 成 员 : “是 的 。 测 试 机 器 挺 烂 的 ， 不 过 在 测试 时 还 是 能 处 理 
50000 个 并 发 请 求 。” 


ScrumMaster: “你 怎么 知道 的 ? ” 


团队 成 员 《被 折磨 得 要 抓 狂 ) : “我 有 报告 啊 ! 你 可 以 自己 看 ， 报 
告 上 都 有 怎么 配置 测试 环境 ， 发 出 了 多 少 个 请 求 ! ” 


ScrumMaster:  “ 那 太 好 了 ! ABBE IRAN TRAN MM! 给 大 家 看 看 你 
的 报告 束 行 了 。 这 比 什 么 都 没有 强 ， 不 是 吗 ? ” 


团队 成 员 : R? 这 就 够 了 吗 ? 不 过 报告 挺 难看 的 ， 得 花 点 时 间 半 


Ua? 





ScrumMaster: “好 的 ， 不 过 不 要 人 花 太 多 时 间 。 不 用 很 好 看 ， 只 要 
能 传递 信息 就 行 。” 


第 10 章 ”我 们 怎样 做 Sprint 回顾 


m ”我 我 们 如 何 组 织 回顾 
m 在 团队 间 传播 经 验 
a X, GRRE 


四 ”回顾 中 发 现 的 问题 示例 


在 有 关 回 顾 的 种 种 一 切中 ， 最 重要 的 就 是 确保 能 够 进行 回顾 。 


由 于 某 些 原 因 ， 团 队 常 常 都 不 太 愿 意 做 回顾 。 如 果 不 给 他 们 一 点 儿 
温柔 的 刺激 ， 我 们 的 大 多 数 团队 都 会 跳 过 回顾 ， 和 直接 进 行 下 一 个 
sprint。 也 许 这 只 是 瑞典 的 文化 ， 我 不 太 确 定 。 


不 过 ， 看 起 来 每 个 人 都 觉得 回顾 的 用 途 极 大 。 说 名 实话 ， 我 认为 回 
顾 是 Scrum 中 第 二 重要 的 事件 (最 重要 的 是 sprint 计 划 会 议 ) ， 因 为 这 是 
你 做 改进 的 最 佳 时 机 ! 





当然 ， 你 不 需要 在 回顾 会 议 上 得 到 什么 好 点 子 ， 在 家 中 的 浴盆 里 就 
能 做 得 到 ! 但 是 团队 会 接受 你 的 想法 么 ? 也 许 吧 ， 不 过 如 果菜 个 主意 
RAM, 换 句 话说 ， 在 回顾 会 议 上 ， 每 个 人 部 可 以 页 献 和 讨论 想 
法 ， 这 时 候 得 到 茶 个 主意 ， 它 会 更 容易 被 大 家 接受 。 








如 果 没 有 回顾 ， 你 就 会 发 现 团队 在 不 断 重 犯 同样 的 错误 。 


我 们 如 何 组 织 回 顾 


根据 情况 不 同 ， 我 们 常用 的 做 法 也 会 有 些 差异 ， 但 是 一 般 都 会 做 以 
下 这 些 事情 。 





四 ”根据 要 讨论 的 内 容 范围 ， 设 定时 间 为 1 至 3 个 小 时 。 
四 ”参与 者 包括 产品 负 贡 人 ， 人 整个 团队 还 有 我 自己 。 


四 ”我 们 换 到 一 个 封闭 的 房间 中 ， 或 者 舒适 的 沙发 角 ， 或 者 屋顶 平 
台 等 等 类 似 的 场所 。 只 要 能 够 在 不 受 干扰 的 情况 下 讨论 就 好 。 

四 ”我 们 一 般 不 会 在 团队 房间 中 进行 回顾 ， 因 为 这 往往 会 分 散 大 家 
的 注意 力 。 

e JERA AWE. 

加 ”ScrumMaster 同 大 家 展示 sprint backlog， 在 团队 的 帮助 下 对 sprint 
做 总 结 。 包 括 重要 事件 和 决策 等 。 


四 ”我们 会 轮流 发 言 。 每 个 人 都 有 机 会 在 不 被 人 打 断 的 情况 下 讲 出 
自己 的 想法 ， 他 认为 什么 是 好 的 ， 哪 些 可 以 做 得 更 好 ， 哪 些 需 
要 在 下 个 sprint 中 改变 。 


四 ”我 们 对 预 估 生产 率 和 实际 生产 率 进 行 比较 。 如 果 兰 异 比 较 大 的 
话 ， 我 们 会 分 析 原 因 。 


别 ” 快 结束 的 时 候 ，ScrumMaster 对 具体 建议 进行 总 结 ， 得 出 下 个 
sprint 需 要 改进 的 地 方 。 


我 们 的 回顾 会 议 一 般 没 有 太 规 整 的 结构 。 不 过 潜在 的 主题 都 是 一 样 
的 : “我 们 怎样 才能 在 下 个 sprint 中 做 得 更 好 ?”。 





下 图 是 我 们 近期 一 次 回顾 的 白板 。 





图 中 的 三 列 分 别 如 下 。 


m Good ”如 果 我 们 可 以 重 做 同一 个 sprint， 哪 些 做 法 可 以 保留 ? 


= Could have done better ”如 果 我 们 可 以 重 做 同一 个 sprint， 哪 些 
做 法 需要 改变 ? 


m Improvements ”有关 将 来 如 何 改进 的 具体 想法 ? 
第 一 列 和 第 二 列 是 回顾 过 去 ， 第 三 列 是 展望 将 来 。 


团队 通过 头脑 风 其 得 出 所 有 的 想法 ， 写 在 即时 贴 上 ， 然 后 用 “ 圆 点 


投票 "来 决定 下 一 个 sprint 会 着 重 进行 哪些 改进 。 每 个 人 都 有 三 块 小 磁 
铁 ， 投 票 决 定 下 个 sprint 所 要 采取 措施 的 优先 级 。 他 们 可 以 随意 投票 ， 
也 可 以 把 全 部 三 票 投 在 一 件 事情 上 。 








根据 投票 情况 ， 他 们 选 出 了 要 重点 进行 的 5 项 过 程 改进 ， 在 下 一 个 
回顾 中 ， 他 们 会 跟踪 这 些 改 进 的 执行 情况 。 





不 过 不 要 想 一 口吃 成 个 胖子 ， 这 一 点 很 重要 。 每 个 sprint 只 关注 几 
AN BES T o 


在 团队 间 传 播 经 验 


一 般 来 说 ， 在 sprint 回 顾 中 得 出 的 信息 都 特别 有 价值 。 团 队 之 所 以 
很 难 全 心 投 入 工作 ， 是 不 是 因为 销售 经 理 常 常 揪 出 开发 人 员 去 在 销售 会 
议 上 充当 “技术 专家 ”? 这 条 信息 很 重要 。 或 许 其 他 团队 也 有 相同 问题 ? 
我 们 是 不 是 应 该 把 更 多 的 产品 知识 教 给 产品 管理 人 员 ， 让 他 们 能 目 己 做 
销售 文 持 ? 





sprint 回 顾 不 只 关注 团队 怎样 才能 在 下 个 sprint 中 做 得 更 好 ， 它 有 更 
RANG Xo 

我 们 的 处 理 策 略 比 较 简 单 。 有 一 个 人 “我 们 这 儿 是 我 ) 会 参加 所 有 
的 Sprint 回顾 会 议 ， 充 当知 识 桥梁 。 不 用 太 正 二 八 经 。 


男 一 种 方式 ， 是 让 每 个 Scruam 团 队 都 发 布 sprint 回 顾 报 告 。 我 们 试 过 
这 么 做 ， 但 发 现 很 多 人 都 不 会 去 读 报 告 ， 而 就 此 展开 改进 的 就 更 少 了 。 
所 以 我 们 还 是 用 了 上 面 那 种 简单 的 方式 。 





充当 “知识 桥 染 * 的 人 需要 服从 下 面 这 些 重 要 规则 。 
四 ”他 应 当 是 一 个 很 好 的 倾听 者 。 


四 ”如 果 回 顾 会 议 过 于 沉 窗 ， 他 应 该 问 一 些 简单 而 目标 明确 的 问 
题 ， 以 刺激 团队 展开 讨论 。 例 如 “如 果 时 间 可 以 倒流 ， 从 第 一 
天 重新 开始 这 个 sprint， 那 你 觉得 哪些 事情 会 用 其 他 方式 来 
做 ? ” 


m 他 应 该 自愿 花 时 间 参 加 所 有 团队 的 全 部 回顾 。 


m 他 应 该 有 一 定 的 行政 权力 ， 如 果 出 现 一些 团 队 无 法 控制 的 改进 
建议 ， 他 可 以 帮助 推进 实施 。 


这 种 做 法 确实 很 棒 ， 不 过 也 许 还 有 其 他 更 好 的 方式 ， 如 果 你 知道 的 
话 ， 还 请 指 反 我 一 下 。 


假设 团队 总 结 出 的 结论 是 ; “我 们 团队 内 部 交流 得 太 少 了 ， 所 以 总 
是 会 重复 彼此 做 过 的 工作 ， 而 且 把 其 他 人 的 设计 搞 得 一 团 精 。” 








我 们 该 怎么 做 昵 ? 引入 每 日 设计 会 议 ? 引入 有 助 于 交流 的 新 工具 ? 
增加 更 多 的 wiki 页 面 ? 唔 ， 也 许 吧 。 不 过 也 不 一 定 。 


我 们 发 现 :很 多 时 候 ， 只 要 能 清楚 地 指出 问题 所 在 ， 到 了 下 一 个 
sprint， 问 题 也 许 就 自行 解决 了 。 把 sprint 回 顾 结果 贴 在 团队 房间 的 墙 上 
(我 们 常常 忘 了 这 一 点 ， 可 真 于 人 ! ) 会 更 有 效 。 在 sprint 中 引入 的 每 
一 点 变化 ， 都 会 让 团队 付出 相应 的 代价 ;在 引入 变化 之 前 ， 可 以 先 考虑 
什么 都 别 做 ， 寄 希望 于 问题 自动 消失 (或 变 小 ) 。 





上 面 ““ 我 们 团队 内 部 交流 得 太 少 了 .……”) 束 是 一 个 很 典型 的 例 
子 ， 说 明 什 么 部 不 做 残 有 可 能 解决 问题 。 

如 果 每 次 有 人 发 几 句 牢骚 ， 你 就 引入 新 的 变化 ， 那 人 们 就 不 愿意 再 
说 小 问题 了 ， 这 就 大 为 不 妙 。 


回顾 中 友 现 的 问题 示例 


下 面 是 在 sprint 回 顾 会 议 上 常常 会 发 现 的 一 些 问题 ， 以 及 相应 的 典 
型 处 理 动作 。 





“我 们 应 花 更 多 时 间 ， 把 故事 拆 分 成 更 小 的 条 目 和 任务 ” 


这 个 问题 很 普遍 。 每 天 的 例会 上 ， 都 会 有 人 说 “我 真 的 不 知道 今天 
该 干什么 ”。 所 以 在 每 一 个 例会 之 后 ， 你 都 要 人 花 些 时 间 来 找 出 具体 任 
务 。 通 凋 这 些 事情 提前 做 会 更 有 效率 。 


典型 动作 





无 。 团 队 很 可 能 会 在 下 一 个 sprint 计 划 会 议 上 自己 解决 掉 这 个 问 
题 。 如 果 它 重复 出 现 的 话 ， 束 延 长 Sprint 计划 会 议 的 时 间 。 


“ 太 多 的 外 界 干扰 > 
典型 动作 


e 让 团队 在 下 一 个 sprint 上 减少 投入 程度 ， 这 样 惑 可 以 有 更 合理 的 
TP. 














四 ”让 团队 在 下 一 个 sprint 上 把 干扰 因素 记录 得 更 清楚 一 些 : 谁 带 来 
的 干扰 ， 占 用 了 多 长 时 间 。 也 许 这 可 以 帮助 我 们 在 下 次 更 好 地 
解决 问题 。 





m ”让 团队 试 着 将 所 有 的 干扰 因素 转 给 ScrumMaster 或 产品 负 贡 人 。 





m 让 团队 指定 一 个 人 充当 “守门 员 ”， 所 有 的 干扰 都 要 经 由 他 处 


理 ， 其 他 人 就 可 以 把 注意 力 保持 在 项 目 上 。 扮 演 者 可 以 是 
ScrumMaster， 也 可 以 大 家 轮流 。 


“我 们 做 出 了 过 上 度 的 承 诡 ， 最 后 只 完成 了 一 半 工 作 ?” 
典型 动作 


无 。 下 一 次 这 个 团队 就 不 会 过 度 承 话 了 ， 或 者 至少 不 会 像 这 次 一 样 
承 诡 得 这 么 多 。 


“我 们 办 公 室 的 环境 太 吵 太 混乱 了 ” 


典型 动作 





e ” 试 者 创建 一 个 更 好 的 环境 ， 或 者 把 团队 搬出 去 。 租 一 间 宾 馆 的 
房间 。 怎 样 都 行 。 参 见 第 7 章 “ 我 们 怎样 布置 团队 房间 ”。 


m 如 条 不 可 能 的 话 ， 那 就 让 团队 在 下 次 sprint 上 降低 投入 程度 ， 并 
明确 注 明 这 是 由 于 嘲 杂 混乱 的 环境 导致 的 。 和 希望 这 可 以 让 产品 
负责 人 开始 找 上 层 管理 者 反映 这 种 问题 。 


幸运 的 是 ， 我 遇 到 的 状况 还 没有 糟糕 到 要 威胁 把 团队 搬出 办 公 室 
去 。 如 果 被 和 无 条 的 话 ， 我 会 这 样 做 的 : 0) 


第 11 章 sprint 之 间 的 休整 时 刻 


在 实际 生活 中 ， 你 不 可 能 一 直 像 上 紧 发 条 一 样 始终 高 速 工作 。 你 需 
要 在 冲刺 的 间 短 休息 。 如 果 弦 总 是 绷 得 那么 紧 ， 实 际 上 并 不 会 有 太 大 成 
效 。 

这 对 Scrum 和 软件 开发 也 一 样 。sprint 安 排 得 很 紧凑 。 作 为 开发 人 
员 ， 你 不 会 有 偷懒 的 机 会 ， 每 天 你 都 得 在 那个 该 死 的 会 议 上 站 起 来 告诉 
每 个 人 你 上 昨天 完成 了 什么 。 几 乎 没 人 愿意 说 : “我 昨天 基本 上 一 直 把 腿 
贡 在 果子 上 ， 看 博客 ， 喝 卡 布 基诺 。” 











除了 真正 的 休息 以 外 ， 还 有 一 个 很 好 的 理由 让 我 们 在 sprint 之 间 进 
行 修整 。sprint 演 示 和 回顾 结束 以 后 ， 团 队 和 产品 负责 人 都 有 一 大 堆 信 
息 和 想法 需要 消化 。 如 果 他 们 立刻 计划 下 一 个 sprint， 那 就 没 人 能 有 机 
会 消化 现 有 的 信息 或 是 学 到 的 经 验 ， 产 品 负责 人 也 没有 时 间 在 sprint 演 


示 以 后 调整 优先 级 。 











下 面 的 安排 比较 差 。 
Monday 


09-10: Sprint 1 demo 


10-11: Sprint 1 retrospective 


13-16: Sprint 2 planning 





我 们 试 着 在 局 动 新 的 sprint 之 前 先进 行人 条 种 形式 的 修整 (精确 地 


说 ， 是 在 sprint 回 顾 之 后 ， 下 一 个 Sprint 计划 会 议 之 前 ) 。 不 过 我 们 也 失 
败 过 


但 最 起 码 ， 我 们 会 力求 保证 不 在 同一 天 举行 Sprint 回顾 和 下 一 个 
sprint 计 划 会 议 。 在 局 动 新 的 Sprint 之 前 ， 每 个 人 都 应 该 至 少 度 过 一 个 不 
需要 考虑 sprint 的 夜晚 。 





下 面 的 安排 稍 好 一 些 。 


Monday Tuesday 


09-10: Sprint 1 demo 9-13: Sprint 2 planning 


10-11: Sprint 1 retrospective 





下 面 的 安排 更 好 。 








Friday Saturday Monday 


09-10: Sprint 1 demo 
10-11: Sprint 1 retrospective 


9-13: Sprint 2 planning 





“实验 日 "《〈 你 爱 叫 什么 都 行 ) 算是 一 种 方式 。 在 这 样 的 日 子 里 ， 开 
发 人 员 基 本 上 可 以 做 任何 他 想 做 的 事情 (OK， 我 承认 这 种 想法 是 从 
Google 来 的 ) 。 比 如 研习 最 新 的 工具 和 API、 准 备 认 证 、 跟 同事 讨论 乱 
七 八 糟 的 事情 、 开 发 自己 喜欢 的 项 目 ， 等 等 。 





我 们 的 目标 是 在 每 个 sprint 之 间 安 排 一 个 实验 日 。 这 样 你 就 能 得 到 


目 然 的 体 轧 ， 开 发 团队 也 能 让 目 己 了 解 最 前 治 的 知识 。 这 也 是 一 种 能 够 
吸引 员工 的 福利 。 


下 面 的 安排 最 好 。 
Thursday Friday E Saturday T ‘Sunday | Monday 
09-10: Sprint 1 demo 9-13: Sprint 2 planning 


10-11: Sprint 1 retrospective LAB DAY 


目前 我 们 每 个 月 有 一 次 实验 日 ， 放 在 每 月 的 第 一 个 星期 五 。 为 什么 
不 放 在 Sprint 之 间 昵 ? 唔 ， 因 为 我 觉得 整个 公司 应 当 在 同样 的 时 间 度 过 
实验 日 ， 否 则 就 会 有 人 不 上 心 。 而 且 我 们 〈 到 目前 为 止 ) 还 没有 把 所 有 
产品 的 sprint 时 间 安 排 都 协调 一 致 ， 所 以 我 不 得 不 选 一 个 跟 sprint 无 关 的 
实验 日 。 


也 许 有 一 天 我 们 会 试 着 对 所 有 产品 的 sprint 进 行 同步 (也 就 是 所 有 
的 产品 跟 团 队 部 有 相同 的 sprint 局 动 时 间 和 结束 时 间 〉。 这 时 候 我 们 就 
肯定 会 选择 两 个 sprint 之 间 的 日 子 当 实验 日 了 。 





第 12 章 ”怎样 制定 发 布 计划 ， 处 理 
国定 价格 的 合同 


四 ”定义 你 的 验收 标准 








四 ”对 最 重要 的 条 目 进行 时 间 佑 算 
四 ”估算 生产 率 

四 ”统计 一 切 因素 ， 生 成 发 布 计划 
四 ”调整 及 布 计划 





有 时 候 ， 一 次 只 计划 一 个 Sprint 中 要 做 的 事情 会 略 显 不 足 ， 我 们 还 
得 提前 多 做 些 计 划 。 尤 其 是 签 了 固定 价格 的 合同 之 后 ， 我 们 就 不 得 不 
预先 计划 了 ， 不 然 就 会 有 无 法 按期 交付 的 危险 。 


一 般 来 讲 ， 制 定 发 布 计划 是 在 尝试 回答 这 个 问题 “最 晚 到 什么 时 
候 为 止 ， 我 们 可 以 交付 这 个 新 系统 的 1.0 版 本 ? ” 





如 果 你 真 的 ”” 想 学 习 有 关 友 布 计划 的 知识 ， 我 建议 你 还 是 跳 过 这 
革 ， 去 买 本 Mike Cohn 的 书 《 敏 捷 估计 与 规划 》。 我 真 布 望 能 够 早点 读 
到 这 本 书 。〔 我 是 在 自己 解决 完 这 种 问题 之 后 才 读 到 它 的 .…...) 我 对 
发 布 计划 的 认识 比较 简单 ， 不 过 用 来 入 门 也 兰 不 多 了 。 


定义 你 的 验收 标准 


除了 普通 的 产品 backlog 之 外 ， 产 品 负责 人 还 会 定义 一 系列 的 验收 
标准 ， 它 从 合同 的 角度 将 产品 backlog 中 重要 性 级 别 的 含义 进行 了 简单 


分 类 。 


下 面 是 验收 标准 规则 的 一 个 例子 。 


m ”所 有 重要 性 > 三 100 的 条 目 都 必须 在 1.0 版 中 发 布 ， 不 然 我 们 就 
BBN KATE 


me 所 有 重要 性 在 50 一 99 之 间 的 条 目 应 该 “在 1.0 中 发 布 ， 不 过 也 许 
我 们 可 以 在 紧 接着 的 一 个 快速 发 布 版 中 完成 这 些 。 





加 ”重要 性 在 25 一 49 之 间 的 条 目 也 都 是 需要 的 ， 不 过 可 以 在 1.1 版 中 
发 布 。 


e 重要 性 <25 的 条 目 都 是 不 确定 的 ， 也 许 永远 不 会 用 到 。 





下 面 是 一 个 产品 backlog 的 例子 ， 根 据 上 面 的 规则 有 不 同 标识 。 


130 banana 
120 apple 
115 orange 
110 guava 
100 pear 

95 raisin 

80 peanut 
70 donut 

60 onion 
40 grapefruit 
35 papaya 
10 blueberr 
10 each 


130—100= %4 在 1.0 版 中 发 布 (banana-pear) 
95 一 600 三 应 该 在 1.0 版 中 发 布 (raisin-onion) 
40—10= 也 许可 以 以 后 再 做 (grapefruit-peach) 


所 以 如 果 我 们 在 最 后 期 限 之 前 能 够 发 布 从 banana 到 onion 的 所 有 条 
目 ， 我 们 就 是 安全 的 。 如 果 时 间 不 够 用 的 话 ， 也 许 我 们 可 以 跳 过 
raisin、peanut、donut、onion。onion 以 下 的 东西 都 算是 额外 的 了 。 





对 最 重要 的 条 目 进行 时 间 佑 算 





为 了 制定 发 布 计划 ， 产 品 负责 人 需要 进行 时 间 估 算 ， 人 至 少 是 要 估算 
在 合同 中 包含 的 故事 。 We 这 是 产品 负责 人 和 团队 
协作 共同 完成 的 一 一 团队 进行 估算 ， 儿 责 人 描述 条 目 内 容 ， 回 答 问 
题 。 

如 果 时 间 佑 算 最 后 被 证 明 接近 正确 结 末 ， 那 它 就 是 有 价值 ”的 ; 如 
果 结 有 果 有 所 偏离 ， 例 如 偏差 了 30%， 价 值 则 有 所 降低 ; 如果 它 跟 实际 结 
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下 图 是 我 根据 做 估算 的 人 、 做 估算 所 用 时 间 以 及 估算 的 价值 三 者 之 
闻 的 关系 所 男 出 的 。 


BA H 占 = 
时 间 估 算 的 团队 的 估算 
价值 


产品 负责 人 的 估算 





做 时 间 估 算 所 花费 的 时 间 





把 图 中 的 含义 换 成 文字 来 表述 就 显得 有 些 罗 吗 。 
四 ”让 团队 来 做 估算 。 


m ”不 要 让 他 们 花 太 多 时 间 。 


四 ”人 确保 他 们 理解 时 间 估 算 只 是 粗略 估算 ， 而 不 是 承 话 。 





通常 产品 负责 人 会 把 整个 团队 聚 到 一 个 房间 ， 提 供 一 些 食品 饮料 ， 
告诉 他 们 这 个 会 议 的 目标 是 得 出 产品 backlog 上 前 20 个 《或 多 少 都 行 ) 故 
事 的 时 间 估 算 。 他 先 讲 一 志 所 有 的 故事 ， 然 后 让 团队 开始 工作 。 他 会 待 
在 房间 里 ， 回 答 大 家 的 问题 ， 必 要 时 解释 清楚 每 一 个 条 目的 内 容 范 围 。 
号 像 做 sprint 计 划一 样 ，“ 如 何 做 演示 ”这 个 字段 也 有 助 于 减少 及 生 误 解 的 
风险 。 





这 个 会 议 的 时 间 必 须要 严格 限制 ， 不 然 团 队 束 会 把 大 量 时 间 人 花费 在 
少数 几 个 故事 上 。 


如 宁 产 品 负 责 人 想 在 这 上 面 花 更 多 的 时 间 ， 他 可 以 随后 再 安排 一 个 
会 议 。 团 队 必须 保证 产品 负责 人 可 以 清楚 地 认识 到 这 些 会 议 对 他 们 当前 
sprint 的 影响 ， 这 样 他 就 能 理解 时 间 估 算 这 个 活动 本 里 也 是 有 代价 的 
Ta 





下 面 是 一 个 时 间 佑 算 结 果 的 例子 〈 以 故事 点 表示 ) 。 


Iv 


Hilt 


banana 
apple 
orange 
guava 


pear 


peanut 


donut 


grapefruit 
papaya 
blueberry 


each 


12 


20 


20 


12 


10 


10 
14 


估算 生产 率 


OK， 现 在 我 们 对 最 重要 的 故事 有 了 一 些 粗 略 的 时 间 佑 算 。 下 一 步 
是 估算 每 个 Sprint 的 平均 生产 率 。 





这 束 意 味 痢 我 们 要 确定 我 们 的 投入 程度 。 请 参见 第 4 章 中 的 “团队 怎 
样 决定 把 哪些 故事 放 到 sprint 里 面 ? ” 


投入 程度 表示 “团队 有 多 少时 间 可 以 放 在 当前 所 承诺 的 故事 上 ”。 它 
永远 不 可 能 是 100% ， 因 为 团队 会 把 时 间 用 于 完成 未 经 计划 的 条 目 、 切 
换 环 境 、 帮 助 其 他 团队 、 检 碍 邮件 、 修 复 自己 出 问题 的 电脑 、 在 厨房 中 


讨论 政治 等 等 


假设 我 们 决定 了 团队 的 投入 程度 是 50% 〈 相 当 低 了 ， 一 般 我 们 都 是 
70% 左 右 ) ，sprint 长 度 是 3 个 星期 (15 天 ) ， 团 队 是 6 个 人 。 


这 样 来 看 每 个 sprint 都 是 90 个 人 -天 ， 但 是 只 能 完整 交付 45 个 人 -天 的 
故事 (投入 程度 是 50%)。 


所 以 我 们 的 估算 生产 率 是 45 个 故事 点 。 





如 果 每 个 故事 的 估算 都 是 5 天 《实际 不 是 ) ， 那 团队 差不多 就 能 在 
一 个 sprint 中 完成 9 个 故事 。 





统计 一 切 因 素 ， 生 成 发 布 计划 
现在 我 们 有 了 时 间 估 算 和 生产 率 〈45) ， 可 以 很 容易 地 把 产品 
backlog 拆 到 多 个 sprint， 如 下 表 所 示 。 


重要 性 名 称 估算 


sprint 1 


130 banana 


120 apple 
115 
sprint 2 


110 
100 
95 
sprint 3 

80 
70 
60 


重 要 性 估算 
40 14 
sprint 4 
35 , 
10 
10 


在 不 超出 45 这 个 估算 生产 率 的 前 担 下， 我 们 把 每 个 sprint 都 尽 可 能 











EW SWS 


现在 我 们 知道 大 约 需 要 3 个 sprint 来 完成 所 有 “必须 要 的 ”和 “应 该 要 
的 ”。 





3 个 sprint 三 9 个 星期 二 2 个 月 。 这 是 我 们 要 向 客户 许诺 的 最 后 期 限 
么 ?要 视 合同 情况 、 范 围 限 制 有 多 严格 等 等 而 是 。 我 们 通常 都 会 增加 相 
当 多 的 时 间 缓 冲 ， 以 避免 糟糕 的 时 间 佑 算 、 未 预期 的 问题 和 未 预期 的 特 
性 等 造成 影响 。 在 这 种 情况 下 ， 我 们 可 能 会 同意 把 发 布 日 期 定 在 三 个 月 
后 ， 让 我 们 “保留 "一 个 月 。 

















我 们 可 以 每 隔 三 个 星期 就 给 客户 演示 一 些 有 用 的 东西 ， 并 在 过 程 中 
邀请 他 们 更 改 需求 《当然 也 要 看 是 什么 样 的 合同 ) ， 这 很 不 错 。 





调整 友 布 计划 
现实 不 会 调整 自己 来 适应 计划 ， 所 以 我 们 必须 另 谋 出 路 。 


每 个 Sprint 之后， 我 们 都 要 看 一 下 这 个 sprint 的 实际 生产 率 。 如 果实 
际 生 产 率 跟 估算 生产 率 差 距 很 大 ， 我 们 惑 会 给 下 面 的 Sprint 调整 生产 
率 ， 更 新 发 布 计划 。 如 果 这 会 给 我 们 带 来 腑 烦 ， 产 品 负责 人 就 会 跟 客 户 
进行 谈判 ， 或 者 检查 一 下 是 否 能 够 在 不 违反 合同 的 情况 下 调整 郊 围 ， 或 
者 他 跟 团 队 一 起 找 出 一 些 方法 ， 通 过 消除 某 些 在 sprint 中 发 现 的 严重 障 
碍 ， 提 高 生产 率 或 是 投入 程度 。 














产品 负责 人 也 许 会 给 客户 打 电 话说 , “ 哮 ， 我 们 目前 比 进度 稍微 慢 
了 点 ， 不 过 我 相信 如 果 把 ‘embedded Pacman” 这 个 特性 去 掉 的 话 ， 我 们 就 
可 以 在 期 限 之 前 完工 ， 因 为 构建 它 会 用 我 们 很 多 时 间 。 如 果 你 同意 的 
话 ， 我 们 可 以 在 第 一 次 发 布 后 三 周 内 的 后 续 发 布 中 把 它 加 进去 。” 














可 能 这 对 客户 来 说 不 是 好 消 妃 ， 但 至 少 我 们 是 诚实 的 ， 并 且 尽 早 给 
客户 提供 了 选择 一 一 我 们 是 应 该 准时 发 布 最 重要 的 功能 ， 还 是 推 延 一 段 
时 间 ， 人 发布 所 有 的 功能 。 做 出 这 种 选择 通常 都 不 是 难事 : o) 





第 13 革 ”我 们 怎样 结合 使 用 Scrum 
和 XP 


a ”结对 编程 
”测试 驱动 开发 (TDD) 

四 ”持续 集成 

m ”代码 集 体 所 有 权 

m 充满 信息 的 工作 空间 

m ”代码 标准 

m ”可 持续 的 开发 速度 /精力 充沛 地 工作 


要 说 结合 使 用 Scrum 和 XP“《“ 极 限 纺 程 ) 可 以 带 来 累累 人 硕果， 这 坚 无 
争议 。 我 在 网 上 看 到 过 的 绝 大 多 数 资料 都 证 实 了 这 一 点 ， 所 以 我 不 会 花 
时 间 去 讨论 为 什么 要 这 么 做 。 





不 过 ， 我 还 是 会 提 到 一 点 。Scrum 注 重 的 是 管理 和 组 织 实践 ， 而 XP 
关注 的 是 实际 的 编程 实践 。 这 惑 是 为 什么 它们 可 以 很 好 地 协同 工作 一 一 
它们 解决 的 古 不 同 领域 的 问题 ， 可 以 互 为 补充 ， 相 得 益 彰 。 








所 以 ， 我 在 这 里 要 问 现 有 的 实践 证 据 中 加 上 我 自己 的 声音 : 结合 使 
用 Scrum 和 XP 会 有 显著 收获 ! 


下 面 我 会 着 重 讲述 XP 中 最 有 价值 的 一 些 实践 ， 以 及 我 们 在 每 日 工 
作 中 的 应 用 方式 。 我 们 的 团队 并 没有 把 所 有 的 实践 都 试 过 一 过 ， 但 总 的 
来 说 ， 在 绝 大 多 数 层 面 上 结合 使 用 XP 与 Scrum， 我 们 都 已 经 党 试 过 了 。 
有 些 XP 实 践 直 接 和 被 Scrum 解 决 择 了， 可 以 被 视 作 二 者 的 重 登 。 如 “整体 
团队 ”“ 华 在 一 起 ”人 “故事 ”和 * 计 划 游 戏 "。 在 这 些 情况 下 我 们 就 直接 使 
用 了 Scrum。 


结对 编程 


我 们 近来 开始 在 一 个 团队 中 实施 结对 编程 。 效 果 相 当 好 。 虽 然 其 他 
团队 大 多 数 还 没有 进行 太 多 尝试 ， 但 在 一 个 团队 中 使 用 了 几 个 sprint 之 
后 ， 我 已 经 有 了 很 蜗 的 热情 去 指导 其 他 团队 进行 试用 。 








下 和 面 是 到 目前 为 止 有 关 结 对 编程 的 一 些 结论 。 
四 ”结对 编程 可 以 提高 代码 质量 。 


曙 ”结对 编程 可 以 让 团队 的 精力 更 加 集中 。〈 比 如 坐 在 你 后 面 的 那 
个 人 会 提醒 你 ,，“ 咖 ， 这 个 东西 真 的 是 这 个 sprint 必 需 的 吗 ?”) 


E ” 令 人 慰 奇 的 是 ， 很 多 强烈 抵制 结对 编程 的 开 友 人 员 根 本 束 没 有 
尝试 过 ， 而 一 旦 尝试 之 后 就 会 迅速 豆 欢 上 它 。 


四 ”结对 编程 令 人 精疲力竭 ， 不 能 全 天 都 这 样 做 。 
四 ”常常 更 换 结 对 是 有 好 处 的 。 


四” 结对 编程 可 以 增进 团队 间 的 知识 传播 ， 速 度 快 到 令 人 难以 想 
象 。 





e ”有些 人 就 是 不 习惯 结对 编程 。 不 要 因为 一 个 优秀 的 开发 人 员 不 
习惯 结对 编程 加 把 他 置之不理 。 


时 ”可 以 把 代码 审查 作为 结对 编程 的 珍 代 方案 。 


= “领航 员 ”( 不 用 键盘 的 家 伙 ) 应 该 自己 也 有 一 台 机 器 。 不 是 用 
来 开发 ， 而 是 在 需要 的 时 候 稍稍 做 一 些 探索 尝试 、 当 * 司 


机 ”“ 使 用 键盘 的 家 伙 ) 、 遇 到 难题 的 时 候 碍 看 文档 ， 等 等 。 





四 ”不 要 强制 大 家 使 用 结对 编程 。 鼓 励 他 们 ， 提 供 合 适 的 工具 ， 让 
他 们 按照 自己 的 节奏 去 尝试 。 





测试 驱动 开发 CTDD) 





阿门 ! 对 我 来 说 ， 它 比 Scrum 和 XP 还 要 重要 。 你 可 以 拿 走 我 的 房 
子 、 我 的 电视 还 有 我 的 狗 ， 但 不 要 试 着 让 我 停止 使 用 TDD! 如 果 你 不 嘉 
欢 TDD， 那 就 别 让 我 进入 你 的 地 盘 ， 不 然 我 一 定 会 想方设法 偷偷 摸 摸 地 
干 的 : o) 

下 面 是 有 关 TDD 的 一 个 10 秒 钟 总 结 


40» =H o 





MARKSA RARER RSA A A a 5 PB is H 
的 代码 ， 让 和 它 通 过 这 个 测试 ， 接 着 对 代码 进行 重 构 ， 主 要 是 提高 它 的 
可 读 性 和 消除 重复 。 整 理 一 下 ， 然 后 继续 。 


人 们 对 测试 驱动 开发 有 奢 各 种 看 法 。 


me ”TDD 很 难 。 开 发 人 员 需 要 花 上 一 定时 间 才 能 掌握 。 实 际 上 ， 
往往 问题 并 不 在 于 你 用 了 多 少 精力 去 教学 、 辅 导 和 演示 一 一 多 
数 情况 下 ， 开 发 人 员 掌 握 。 它 的 唯一 方式 就 是 跟 一 个 熟悉 TDD 
的 人 一 起 结对 编程 ， 一 旦 掌握 以 后 ， 他 束 会 受到 彻 乓 的 影 
啊 ， 从 此 再 也 不 想 使 用 其 他 方式 工作 。 








me TDD 对 系统 设计 的 正面 影响 特别 大 。 





四 ”在 新 产品 中 ， 需 要 过 上 一 段 时 间 ，TDD 才 能 开始 应 用 并 有 效 运 
行 ， 尤 其 是 黑 盒 集成 测试 。 但 是 回报 来 得 非常 快 。 





四 ”投入 足够 的 时 间 ， 来 保证 大 家 可 以 很 容易 地 编写 测试 。 这 意味 


者 要 有 合适 的 工具 、 有 经 验 的 人 、 提 供 合适 的 工具 类 或 基 类 ， 
等 等 。 








我 们 在 测试 驱动 开发 中 使 用 了 如 下 工具 。 

m ”jUnit/httpUnit/jjWebUnit。 我 们 正在 考虑 使 用 TestNG 和 Selenium. 
m HSQLDB 用 作 和 嵌入 式 的 内 存 数 据 库 ， 在 测试 中 使 用 。 

四 ”Jetty 用 作 嵌 入 式 的 内 存 Web 容 器 ， 在 测试 中 使 用 。 

四 ”Cobertura 用 来 度量 测试 覆盖 率 。 


m Spring 框架 用 来 织 入 不 同类 型 的 测试 装置 〈 带 有 mock、 不 带 
mock、 带 有 外 部 数据 库 或 带 有 内 存 数 据 库 等 等 ) 











在 我 们 那些 经 验 最 丰富 的 产品 中 《从 TDD 的 视角 来 看 ) ， 都 有 自动 
化 的 黑 盒 验收 测试 。 这 些 测 试 会 在 内 存 中 局 动 整 个 系统 ， 包 括 数据 库 和 
Web 服 务 器 ， 然 后 只 通过 系统 的 公共 接口 进行 访问 《例如 HITP) 。 








它 会 把 开发 -构建 -测试 这 三 者 构成 的 循环 变 得 奇 快 无 比 ， 同 时 还 可 
以 充当 一 张 安全 网 ， 让 开发 人 员 有 足够 的 信心 频 楷 重 构 ， 伴 随 独 系统 的 
增长 ， 设 计 依 然 可 以 保持 整洁 和 简单 。 





在 新 代码 上 进行 TDD 





我 们 在 所 有 的 全 新 开发 过 程 中 都 使 用 TDD， 即 便 这 会 在 开始 时 延长 
项 目 配 置 时 间 (因为 我 们 需要 更 多 的 工具 ， 并 为 测试 装备 提供 支持 等 
等 ) 。 其 实用 脚 指 头 思考 也 可 以 知道 ，TDD 带 来 的 好 处 如 此 之 大 ， 还 有 
什么 理由 可 以 不 用 它 呢 。 


在 旧 代 码 上 进行 TDD 


TDD 是 很 难 ， 但 是 在 一 开始 没有 用 TDD 进 行 构建 的 代码 库 上 实施 
TDD...….….. 则 是 难 上 加 难 ! 为 什么 ? 喝 ， 实 际 上 ， 就 这 个 话题 我 可 以 写 
上 许多 页 ， 所 以 我 想 最 好 到 此 为 止 。 也 许 我 会 在 我 的 下 一 个 论文 “硝烟 
中 的 TDD” 中 进行 解释 : o) 


我 们 曾 花 了 大 量 的 时 间 ， 在 一 个 比较 复杂 的 系统 上 进行 自动 化 集成 
测试 ， 它 的 代码 库 已 经 存在 很 长 时 间 了 ， 处 于 极度 混乱 的 状态 ， 一 丁点 
的 测试 代码 都 没有 。 











每 次 及 布 之 前 ， 部 有 一 个 由 专门 的 测试 人 员 组 成 的 团队 ， 来 进行 大 
批量 的 、 复 杂 的 回归 测试 和 性 能 测试 。 那 些 回归 测试 大 多 数 痢 是 手工 进 
行 。 我 们 的 开发 和 发 布 周 期 束 这 样 被 严重 延误 了。 我 们 的 目标 是 将 这 些 
测试 目 动 化 ， 但 是 几 个 月 的 痛 吾 豆 熬 以 后 ， 仍 然 没 有 取得 多 少 进展 。 


之 后 我 们 改变 了 方式 。 首 先 承 认 自 己 已 经 陷入 了 手工 回归 测试 的 泥 
潭 ， 然 后 再 来 问 自己 : “怎么 让 手工 回归 测试 消耗 的 时 间 更 少 呢 ?”” 当 时 
开发 的 是 一 个 赌博 系统 ， 我 们 意识 到 : 测试 团队 在 非常 琐碎 的 配置 任务 
上 花费 了 大 量 的 时 间 。 例 如 浏览 后 从 并 创建 牌 局 来 测试 ， 或 者 等 竺 一 个 
安排 好 的 牌 局 局 动 。 所 以 我 们 特地 创建 了 一 些 实用 工具 。 这 些 快捷 方式 
和 脚本 很 小 ， 而 且 使 用 方便 。 它 们 可 以 完成 那些 乱七八糟 的 工作 ， 让 测 
试 人 员 专注 于 真正 的 测试 。 








这 些 付出 确实 收 到 了 成 效 ! 实际 上 ， 我 们 的 确 应 该 从 一 开始 就 这 样 
做 。 当 初 太 急于 将 测试 自动 化 了 ， 孝 二 了 应 该 一 步 一 步 走 。 刚 开始 应 该 
想 办 法 提高 手工 测试 的 效率 。 


吸取 的 教训 : 如果 你 深 陷 手工 回归 测试 的 泥潭 ， 打 算 让 它 自动 化 
执行 ， 最 好 还 是 放弃 吧 ( 除 非 做 起 来 特别 简单 ) 。 首 先 还 是 应 该 想 办 法 





简化 手工 回归 测试 。 然 后 再 考虑 将 真正 的 测试 变 成 目 动 化 执行 。 

增 量 设计 

这 表示 一 开始 就 应 该 保持 设计 简单 化 ， 然 后 不 断 进行 改进 ; 而 不 是 
一 开始 努力 保证 它 的 正确 性 ， 然 后 就 冻结 它 ， 不 再 改变 。 

在 这 一 点 上 我 们 做 得 相当 好 ， 我 们 用 了 大 量 的 时 间 来 做 重 构 ， 改 进 
赋 有 设计 ， 而 几乎 没 用 什么 时 间 来 做 大 量 的 预先 设 计 。 有 时 候 我 们 当然 
也 会 出 错 ， 例 如 允许 一 个 不 稳定 的 设计 “陷入 ” 太 深 ， 以 至 于 后 来 代码 重 
构成 了 一 个 大 问题 。 不 过 总 体 来 看 我 们 都 是 相当 满意 的 。 





持续 的 设计 改进 ， 这 在 很 大 程度 上 是 TDD 自 动 带 来 的 成 果 。 


持续 集成 


我 们 的 大 多 数 产 品 在 持续 集成 方面 都 已 经 很 成 熟 了 ， 它 们 是 基于 
Maven 和 QuickBuild 的 。 这 样 做 很 管用 ， 而 且 节 省 了 我 们 大 量 时 间 。 对 
FI, CERA 电脑 上 没有 问题 ”这 样 的 老 问题 ， 持 续集 成 也 是 终极 解 
决 方案 。 要 判断 所 有 代码 库 的 健康 状况 ， 可 以 用 持续 构建 服务 器 充 
当 “ 法 官 ” 或 是 参考 点 。 每 次 有 人 同 版 本 控制 系统 中 check ” ”in 东西 ， 持 续 
构建 服务 器 就 会 醒 来 ， 在 一 个 共享 服务 器 上 从 头 构建 一 切 ， 运 行 所 有 测 
试 。 如 果 出 现 问题 ， 它 就 会 同 整个 团队 发 送 邮 件 告 知 大 家 构建 失败 ， 在 
邮件 中 会 包括 有 哪些 代码 的 变化 导致 构建 失败 的 精确 细节 ， 指 回 测 试 报 
告 的 链接 等 。 





每 天 上 晚上， 持续 构建 服务 器 都 会 从 头 构建 产品 ， 并 且 辐 我们 的 内 部 
文档 门户 上 发 布 二 进 制 文件 〈ears，wars 等 ) 、 文 档 、 测 试 报告、 测试 
履 盖 率 报 告 和 依赖 性 分 析 报告 等 等 。 有 些 产品 也 会 被 自动 部 署 到 测试 环 
境 中 。 





把 这 一 切 搭建 起 来 需要 大 量 工作 。 ”， 但 付出 的 每 一 分 钟 都 物 有 所 
值 。 


代码 集体 所 有 权 


我 们 鼓励 代码 集体 所 有 权 ， 但 并 不 是 所 有 团队 都 采取 了 这 种 方式 。 
我 们 发 现 : 在 结对 编程 中 频 或 交换 结对 ， 会 自动 把 代码 集体 所 有 权 提 到 
一 个 很 高 的 级 别 。 我 们 已 经 证 实 ， 如 宁 团 队 拥有 高 度 的 代码 集体 所 有 
权 ， 这 个 团队 就 会 非常 健壮 ， 比 如 茶 些 关键 人 物 生 病 了 ， 当 前 的 sprint 
EAA ALC EE OR o 








充满 信息 的 工作 空间 


所 有 团队 都 可 以 有 效 利用 白板 和 空 的 墙壁 空间 。 很 多 房间 的 墙 上 都 
贴 满 了 各 种 各 样 天 于 产品 和 项 目的 信息 。 这 样 做 最 大 的 问题 ， 就 是 那些 
旧 的 作废 信息 也 堆 在 墙 上 ， 也 许 我 们 应 该 在 每 个 团队 中 引入 一 个 “ 管 
家 ”的 角色 。 





我 们 或 励 使 用 任务 板 ， 但 是 并 不 是 所 有 团队 都 采用 了 它 。 参 见 第 7 
章 “ 我 们 怎样 布置 团队 空间 ”。 





代码 标准 


不 久 前 我 们 开始 定义 代码 标准 。 它 的 用 处 很 大 ， 要 是 我 们 早 这 样 做 
就 好 了 。 引 入 代码 标准 几乎 没 花 多 少时 间 ， 我 们 只 是 一 开始 从 简单 入 
手 ， 让 它 慢 慢 增长 。 只 需要 写 下 不 是 所 有 人 都 了 如 指 掌 的 事情 ， 并 尽 可 
能 加 上 对 外 部 资料 的 链接 。 











绝 大 多 数 程序 员 都 有 他 们 目 己 特定 的 编程 风格 。 例 如 他 们 如 何 处 理 
异常 ， 如 何 注释 代码 ， 何 时 返回 null 等 等 。 有 时 候 这 种 差异 没什么 关 
系 ， 但 在 东 些 情况 下 ， 系 统 设计 束 会 因此 出 现 不 一 致 的 现象 ， 情 况 严 
重 ， 代 码 也 不 容易 看 懂 。 这 时 代码 标准 的 用 处 就 会 凸显 ， 从 造成 影响 的 
因素 中 就 可 以 知道 了 。 








下 面 是 我 们 代码 标准 中 的 一 些 例子 。 

m 你 可 以 打破 这 里 的 任 一 规则 ， 不 过 一 定 要 有 个 好 理由 ， 并 且 记 
录 下 来 。 

四 ”默认 使 用 Sun 的 代码 惯例 : 


http://java.sun.com/docs/codeconv/html/CodeConvTOC.doc.html. 


m K, Kit, KAREKA HERRERA (stack trace) 
或 是 重新 抛 出 异常 的 情况 下 捕获 异常 。 用 log.debug O 也 不 
错 ， 只 要 别 丢 失 堆 栈 跟踪 信息 就 行 。 





四 ”使 用 基于 setter 方 法 的 依赖 注入 来 将 类 与 类 解 灶 (当然 ， 如 果 紧 
契合 可 以 令 人 满意 的 话 就 娘 当 别论 〉。 


四 ”避免 缩写 。 为 人 熟知 的 缩写 则 可 以 ， 例 如 DAO。 


m 需要 返回 Collections 或 者 数组 的 方法 不 应 该 返回 nul。 应 该 返回 
空 的 容器 或 数组 ， 而 不 是 null。 


可 持续 的 开发 速度 /精力 充沛 地 工作 


很 多 有 关 敏 捷 软件 开发 的 书 都 声称 ,加班 工 作 在 软件 开发 中 会 降低 
生产 率 。 





经 过 几 次 不 情愿 的 试验 之 后 ， 我 完全 拥护 这 种 说 法 ! 


大 约 一 年 以 前 ， 我 们 中 有 一 个 团队 《最 大 的 团队 ) EJEM. W 
存 代码 库 的 质量 惨不忍睹 ， 他 们 不 得 不 投入 绝 大 多 数 的 时 间 来 救火 。 测 
试 团队 《同样 也 在 加 班 ) 根本 没 时 间 来 认真 地 做 质量 保证 工作 。 我 们 的 
用 户 很 生气 ， 小 道 消 息 和 流言 也 快 把 我 们 活活 吞 掉 了 。 


几 个 月 后 ， 我 们 成 功 地 把 大 家 的 工作 时 间 缩 短 到 了 适当 的 范围 。 他 
们 正常 上 下 班 《 除 了 有 时 候 在 项 目 关键 期 要 加 班 以 外 ) 。 令 人 惊异 的 
征 ， 生 产 率 和 质量 都 取得 了 显著 提高 。 








当然 ， 减 少 工作 时 长 绝 不 是 带 来 改进 的 唯一 ”因素 ， 但 我 们 都 确信 
它 的 影响 很 大 。 


第 14 章 ”我 们 怎样 做 测试 


你 大 概 没 法 取消 验收 测试 阶段 
把 验收 测试 阶段 缩 到 最 短 
把 测试 人 员 放 到 Scrum 团 队 来 提高 质量 





在 每 个 sprint 中 少 做 工作 来 提高 质量 


回 到 现实 


这 是 最 困难 的 部 分 。 我 不 知道 它 到 底 只 是 Scrum 中 最 困难 的 部 分 ， 
还 是 在 软件 开发 中 通常 部 是 最 困难 的 部 分 。 








在 不 同 组 织 的 各 种 开发 活动 中 ， 测 试 可 能 是 送 异 最 大 的 。 它 依赖 于 
你 有 多 少 个 测试 人 员 、 系 统 类 型 〈 只 是 服务 器 +Web 应 用 ， 还 是 交付 完 
整 的 软件 ? ) 、 发 布 周 期 的 长 短 、 软 件 的 重要 性 (博客 服务 器 Vs. 飞行 控 
制 系统 ) ， 等 等 。 


我 们 曾经 符 试 过 多 种 在 Scrum 中 做 测试 的 方式 。 下 面 我 会 尽力 描述 
一 下 我 们 的 做 法 ， 以 及 到 目前 为 止 掌握 的 经 验 。 


你 大 概 没 法 取消 验收 测试 阶段 


在 理想 化 的 Scrum 世 界 中 ， 每 个 sprint 最 终 会 产生 一 个 可 部 署 的 系统 
版 本 。 那 赶紧 部 署 就 好 了 ， 是 么 ? 
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不 是 。 


根据 我 们 的 经 验 ， 这 样 做 一 般 部 是 不 成 的 。 很 恶心 的 bug 会 因此 出 
现 。 如 果 质 量 对 你 来 说 还 算 重要 ， 你 就 应 该 进行 验收 测试 。 此 时 ， 团 队 
之 外 的 专职 测试 人 员 会 用 测试 来 攻击 系统 ， 而 且 这 些 测试 是 Scrum 团 队 
要 么 考虑 不 到 ， 要 么 没有 时 间 完 成 ， 或 是 限于 硬件 条 件 无 法 完成 的 。 测 
试 人 员 会 采取 与 终端 用 户 一 模 一 样 的 方式 来 操作 系统 ， 也 就 是 说 他 们 必 
须要 手工 进行 测试 《假设 你 的 系统 用 户 是 人 ) 。 
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测试 团队 会 发 现 bug，Scrum 团 队 就 得 发 布 针对 bug 修 复 的 版 本 ， 或 
早 或 晚 (希望 更 早 一 些 ) 你 就 要 为 终端 用 户 友 布 修复 了 bug 的 1.0.1 扳 
本 ， 而 不 是 问题 重重 的 1.0.0 版 本 。 


我 说 的 “验收 测试 阶段 ?， 是 指 整个 测试 、 调 试 、 重 新 发 布 阶段 ， 直 
到 得 到 可 以 用 来 做 产品 发 布 的 版 本 为 止 。 





把 验收 测试 阶段 缩 到 最 短 


验收 测试 阶段 会 让 人 受 不 了 。 那 的 确 让 人 觉得 不 太 敏 捷 。 虽 然 我 们 
不 能 逃避 这 个 阶段 ， 但 可 以 想 办 法 尽量 缩短 时 间 。 说 得 更 明白 一 些 ， 把 
再 要 花 在 验收 测试 阶段 上 的 时 间 减 到 最 少 。 我 们 采取 的 是 以 下 做 法 。 





四 ”全 力 提 高 Scrum 团 队 交 付 的 代码 质量 。 


E ”全力 提 高 人 工 测 试 工作 的 效率 〈 即 ， 找 到 最 好 的 测试 人 员 ; 给 
他 们 最 好 的 工具 ; 确保 他 们 上 报 那 些 耗费 时 间 、 却 能 够 被 自动 
化 完成 的 工作 ) 。 





那 我 们 该 怎么 提高 Scrum 团 队 提 交 的 代码 质量 呢 ? 喝 ， 办 法 还 是 很 
多 的 。 我 们 发 现下 面 这 两 种 办 法 效果 很 好 。 


”把 测试 人 员 放 到 Scrum 团 队 中 。 


四 ”每 个 Sprint 少 做 点 工作 。 


把 测试 人 员 放 到 Scrum 团 队 来 提高 质量 
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是 的 ， 我 听 到 过 对 芯 的 意见 : 





m “很 明显 啊 ! Scrum 团 队 应 该 是 路 职能 的 ! ” 


m “Scrum 团 队 应 该 是 没 角色 的 ! 我 们 不 能 把 只 做 测试 的 人 放 到 里 
面 来 ! ” 
让 我 澄清 一 下 。 这 里 我 说 的 "测试 人 员 * 指 的 是 “主要 技能 是 测试 的 
人 ”， 而 不 是 “只 做 测试 的 人 ”。 





开发 人 员 常 津 部 是 很 差劲 的 测试 人 员 ， 尤 其 ”是 他 们 测试 自己 代码 
的 时 候 。 


测试 人 员 就 是 “验收 的 家 伙 ” 








除了 “只 是 ”个 团队 成 员 以 外 ， 测 试 人 员 还 有 个 重要 的 工作 要 做 。 他 
负责 验收 。sprint 中 的 任何 工作 ， 如 果 他 ”不 说 完成 ， 那 就 不 能 算 完 成 。 
我 发 现 开 发 人 员 和 常常 说 一 些 工作 已 经 完成 了 ， 但 事实 并 非 如 此 。 即 使 你 














有 一 个 很 明确 的 对 “完成 ?的 定义 〈 你 确实 应 该 如 此 ， 参 见 第 4 章 中 的 “ 定 
义 ' 完 成 ”) ， 开 及 人 员 也 会 经 常态 挥 。 我 们 这 些 编程 的 人 都 不 怎么 有 了 耐 
心 ， 一 心 想 着 尽快 去 做 下 一 个 条 目 。 











那么 我 们 的 测试 先生 ”怎么 知道 茶 些 事情 已 经 完成 呢 ? WA, EPG, 
他 应 该 测试 E! 《吃惊 吧 ? ) 我 们 经 名 都 会 发 现 : 开发 人 员 认 为 “ 完 
成 ”的 工作 ， 却 根本 无 法 测试 ! 原因 包括 代码 没有 提交 ， 或 者 还 没有 部 
蜀 到 测试 服务 器 上 ， 等 等 。 一 旦 测试 先生 开始 测试 这 个 特性 ， 他 束 应 该 
跟 开 及 人 员 一 起 浏 宽 一 过“ 完成 ”检查 列表 如果 你 有 的 话 ) 。 例 如 ， 如 
果 在 “完成 ”的 定义 中 写 着 一 定 要 有 版 本 说 明 ， 那 测试 完 生 就 要 去 检查 是 
不 是 有 版 本 说 明 。 如 果 对 这 个 特性 有 比较 正式 的 规范 说 明 (我 们 这 里 很 
少 有 这 种 情况 ) ， 测 试 先 生 就 要 据 此 进行 检查 。 如 此 等 等 ， 不 一 而 足 。 














妙 处 由 此 而 生 。 这 下 团队 中 整 有 了 这 样 一 个 人 ， 可 以 完美 地 担当 
组 织 sprint 演 示 的 职责 。 











如 果 没 有 任何 事情 需要 测试 ， 那 测试 人 员 该 做 什么 


这 个 问题 会 种 和 出 现 。 测 试 先 生 会 说 :“ 嘿 ，ScrumMaster， 目 前 没 
有 什么 东西 需要 测试 ， 那 我 该 做 什么 呢 ? "也 许 团 队 需 要 一 个 星期 才能 
完成 第 一 个 故事 ， 那 这 段 时 候 测 试 人 员 该 做 什么 呢 ? 











唱 ， 首 先 ， 他 应 该 要 为 测试 做 准备 ”。 包 括 编写 测试 规范 ， 准 备 测 
试 环境 等 等 。 开 发 人 员 有 开发 完 的 功能 可 供 测试 以 后 ， 就 不 用 再 等 了 ， 
测试 先生 可 以 立刻 开始 测试 。 








如 末 团 队 在 做 TDD， 从 第 一 天 开始 ， 大 家 都 会 花 时 间 来 编写 测试 代 
码 ， 此 时 测试 人 员 应 该 跟 编 写 测试 代码 的 开发 人 员 一 起 结对 编程 。 如 果 
测试 人 员 根 本 不 会 编程 ， 他 也 应 该 跟 开 发 人 员 结 对 ， 即 便 他 只 能 坐 在 一 


边 看 ， 让 开发 人 员 融 键盘 。 相 对 于 好 的 开发 人 员 ， 好 的 测试 人 员 和 营 第 能 
想 出 多 种 不 同类 型 的 测试 ， 所 以 他 们 可 以 互补 。 


如 末 团 队 没 有 实施 TDD， 或 者 没有 足够 的 测试 用 例 震 要 编写 ， 那 测 
试 人 员 可 以 去 随意 做 一 些 能 够 帮助 团队 达成 sprint 目 标的 事情 ， 束 像 其 
他 团队 成 员 一 样 。 如 果 测 试 人 员 会 编程 ， 那 自然 再 好 不 过 。 如 果 他 不 
会 ， 你 的 团队 束 得 找 出 在 sprint 中 需要 完成 的 、 而 且 不 用 编程 的 工作 。 


在 Sprint 计划 会 议 中 ， 进 行 到 拆 分 故事 阶段 ， 团 队 会 把 注意 力 放 在 
编程 性 任务 上 ， 但 一 般 在 sprint 中 都 会 有 很 多 非 编程 性 任务 需要 完成 。 
如 果 在 sprint 计 划 阶 段 伦 上 一 些 时 间 来 找 出 非 编程 性 任务 o WREN 
有 机 会 来 做 出 大 量 页 献 ， 即 使 他 不 会 编程 ， 当 前 也 没有 测试 工作 要 做 。 











下 面 是 在 sprint 中 需要 完成 的 非 编 程 性 任务 的 例子 : 
四 ”搭建 测试 环境 

四 ”明确 需求 

a 与 运营 部 门 讨论 部 署 的 操作 细节 


四 ”编写 部 团 文 档 ( 版 本 说 明 ，RFC， 或 任何 在 你 们 组 织 中 要 写 的 
东西 ) 


四 ”和 外 界 的 资源 进行 联系 例如 GUI 设 计 师 ) 





四 ”改进 构建 脚本 
四 ”将 故事 进一步 拆 分 成 任务 
四 ”标识 出 来 自 开 发 人 员 的 核心 问题 并 协助 解决 这 些 问 题 


从 忆 一 个 角度 来 看 ， 如 果 测 试 先生 成 了 瓶 氏 ， 那 我 们 该 怎么 办 ? 假 
设 在 sprint 的 最 后 一 天 突然 完成 了 很 多 工作 ， 测 试 先 生根 本 没有 时 间 测 
试 完 所 有 的 事情 。 我 们 怎么 办 ? 不 妨 把 团队 中 的 所 有 人 都 分 配给 测试 先 
生 当 助手 。 他 决定 哪些 事情 自己 来 做 ， 把 一 些 烦人 的 测试 交 给 团队 中 的 
其 他 人 来 做 。 这 就 是 路 职能 团队 该 做 的 事情 ! 








所 以 没 错 ， 测 试 先生 确实 ”在 团队 中 有 一 个 特定 的 角色 ， 不 过 他 仍 
然 可 以 做 其 他 工作 ， 其 他 团队 成 员 也 可 以 做 他 的 工作 。 





在 每 个 sprint 中 少 做 工作 来 提高 
回 到 Sprint 计划 会 议 上 。 简 单 来 说 ， 就 是 别 把 太 多 故事 都 放 到 Sprint 


里 面 去 ! 如 果 碰 到 了 质量 问题 ， 或 者 验收 测试 周期 太 长 ， 干 脆 就 每 个 
sprint 少 干 点 ! 这 会 目 动 带 来 质量 提升 、 验 收 测试 周期 缩短 、 影 响 终 闻 

用 尸 的 bug 减 少 ， 并 在 短期 内 得 到 更 高 的 生产 力 ， 因 为 团队 可 以 始终 关 
注 于 新 的 东西 ， 而 不 是 不 断 修复 出 现 问 题 的 旧 功 能 


说 ， 








相对 于 构建 大 量 功能 ， 然 后 不 得 不 在 惊 颁 失措 的 状态 下 做 热 修复 来 
少 构 建 一些 功 能 ， 但 是 把 它 弄 得 稳定 点 儿 ， 这 样 做 要 合算 得 多 。 


验收 测试 应 该 作为 Sprint 的 一 部 分 么 


我 们 在 这 里 分 卜 较 大 。 有 些 团队 把 验收 测试 当成 了 sprint 的 一 部 








。 但 大 部 分 团队 都 没 这 样 做 。 原 因 主 要 有 两 点 。 





四 ”sprint 是 有 时 间 盒 限制 的 。 验 收 测 试 〈 在 我 的 定义 中 ， 它 要 包括 
调试 和 再 次 发 布 ) 的 时 间 却 很 难 固 定 。 如 果 时 间 用 完了 ， 你 还 
有 一 个 严重 的 bug 怎 么 办 ?是 要 带 着 这 个 严重 bug 交 付 上 线 ， 还 
是 等 到 下 个 sprint 再 说 ?大 多 数 情 况 下 ， 这 两 种 解决 方案 都 是 
不 可 接受 的 。 所 以 我 们 把 人 工 验 收 测试 排除 在 外 。 


四 ”如 果 有 多 个 团队 开 友 同一 个 产品 ， 那 就 得 等 所 有 团队 的 工作 成 
末 合 并 以 后 ， 再 进行 人 工 验收 测试 。 如 果 每 个 团队 都 在 sprint 
中 进行 人 工 验 收 测试 ， 最 后 还 是 要 有 一 个 团队 测试 最 终 版 本 ， 
而 且 这 个 版 本 集成 了 全 部 团队 的 工作 。 
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这 个 解决 方案 不 算 完 美 ， 但 对 我 们 来 说 ， 已 经 可 以 满足 大 多 数 情况 











sprint 周 期 vs. 验 收 测试 周期 


在 完美 的 Scrum 世 界 中 ， 你 根本 不 需要 验收 测试 阶段 ， 因 为 每 个 
Scrum 团 队 在 每 个 sprint 结 束 以 后 ， 都 会 发布 一 个 新 的 可 供 产 品 化 的 版 
本 。 








Sprint 1 || Sprint 2 ] 





时 间 线 





不 过 ， 下 面 这 张 图 就 更 符合 实际 情况 了 。 





| Sprint 1 








在 sprint 1 之 后 ， 我 们 得 到 了 满 是 bug 的 1.0.0 版 本 。 在 sprint 2 中 ，bug 
报告 开始 涌 入 ， 团 队 花 了 大 部 分 的 时 间 来 进行 调试 ， 然 后 又 被 迫 在 
sprint 的 中 期 发 布 了 修复 了 bug 的 1.0.1 版 本 。 到 了 sprint 2 末尾 ， 他 们 发 布 
了 1.1.0 版 本 ， 提 供 了 一 些 新 特性 ， 但 bug 数 量 有 增 无 减 ， 因 为 他 们 从 上 
一 个 版 本 发 布 以 后 就 一 直 被 bug 所 干扰 ， 所 以 能 够 用 来 保证 代码 质量 的 
时 间 就 更 少 。 然 后 就 一 直 这 样 循环 下 去 ..…..…. 


在 sprint 2 中 的 斜 线 表明 有 混乱 的 存在 。 


不 怎么 好 看 ， 是 吧 ? 但 令 人 悲哀 的 是 ， 即 使 你 有 验收 测试 团队 ， 这 
些 问 题 仍 会 存在 。 唯 一 的 区 别 是 ， 在 后 者 中 ， 大 多 数 bug 报 告 会 来 自 于 
测试 团队 ， 而 非 怒 气 冲 冲 的 用 户 。 从 商业 视角 来 看 ， 二 者 之 间 有 着 很 大 
差别 ， 但 对 开发 人 员 而 言 却 几 乎 没什么 两 样 。 不 过 测试 人 员 通 党 都 没有 
用 户 那 么 强势 。 一 般 如 此 。 











终端 用 户 
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我 们 目前 还 没有 发 现 这 个 问题 的 解决 方案 。 不 过 还 是 尝试 过 许多 不 
同 的 模型 。 


首先 ， 还 是 全 力 提 高 Scrum 团 队 发 布 的 代码 质量 。 在 一 个 sprint 中 及 
早 发 现 并 修复 bug， 要 比 sprint 结 束 以 后 再 这 样 做 的 代价 小 得 多 。 





但 事实 还 是 事实 ， 就 算是 我 们 可 以 把 bug 数 量 减少 到 最 小 ， 在 sprint 
结束 后 还 是 有 bug 报 告 出 来 。 那 我 们 是 怎么 做 的 呢 ? 





方式 1: “在 旧版 本 可 以 产品 化 之 前 ， 不 构建 新 特性 ” 


听 起 来 挺 不 错 的 ， 不 是 吗 ? 你 是 否 也 有 这 种 温暖 舒 适 的 感觉 ? 





我 们 曾 几 度 差点 采用 这 种 方式 ， 而 且 还 画 出 了 想象 中 如 何 进行 实施 
的 模型 。 但 是 意识 到 它 的 负面 影响 后 ， 我 们 就 改变 了 主意 。 如 果 这 样 做 
的 话 ， 我 们 残 得 在 sprint 之 间 添 加 一 个 无 时 间 限 制 的 及 布 阶 段 ， 而 且 在 
这 个 时 期 内 只 能 进行 测试 和 调试 ， 直 到 可 以 做 出 产品 发 布 为 止 。 


Sprint 1 RA .Sprint2 发 布 Sprint3 


时 间 线 一 


我 们 不 喜欢 在 sprint 之 间 加 上 无 时 限 的 发 布 阶段 ， 主 要 是 因为 它 可 
能 会 破坏 sprint 的 节 委 。 我 们 再 也 无 法 说 出 “每 三 周 局 动 一 个 新 的 
sprint” 这 样 的 话 来 。 男 外 ， 它 也 没 法 根除 问题 。 即 使 有 一 个 发 布 阶 段 ， 
依然 会 不 时 出 现 紧急 的 bug 报 告 ， 我 们 不 得 不 为 它们 做 好 准备 。 


方式 2: “可 以 开始 构建 新 东西 ， 但 是 要 给 “将 旧 功 能 产品 
化 ?分 配 高 优先 级 ” 





这 是 我 们 了 最 喜欢 的 方式 。 至 少 现在 如 此 。 


一 般 我 们 完成 一 个 sprint 以 后 就 会 开始 进行 下 一 个 。 但 是 我 们 会 在 
接 下 来 的 Sprint 中 花 一 些 时 间 解 决 过 往 sprint 中 留 下 的 bug。 如 果 修 复 bug 
占用 了 太 多 时 间 ， 从 而 导致 接 下 来 的 sprint 遭 到 严重 破坏 ， 我 们 就 会 分 
析 问 题 产 生 的 原因 以 及 如 何 提高 质量 。 我 们 会 确保 sprint 的 长 度 ， 使 之 
足以 完成 对 上 个 sprint 中 一 定数 量 bug 的 修复 。 





随 看 时 间 推 移 ， 经 过 几 个 月 以 后 ， 修 复 上 个 sprint 遗 留 bug 所 用 的 时 


间 就 会 减少 。 而 且 当 bug 发 生 以 后 ， 所 牵扯 的 人 也 更 少 了 ， 所 以 不 会 总 
是 干扰 整个 团队 。 现 在 这 种 做 法 已 经 得 到 了 更 多 人 的 认可 。 
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在 Sprint 计划 会 议 上 ， 考 虑 到 会 花 时 间 修 复 上 个 sprint 的 bug， 所 以 我 
们 会 把 投入 程度 设 得 足够 低 。 经 过 一 段 时 间 ， 团 队 在 估算 方面 已 经 做 得 
很 到 位 了 。 和 生产 率 度 量 也 起 到 了 很 大 帮助 作用 。 参见 第 4 章 中 的 “团队 
怎样 决定 把 哪些 故事 放 到 sprint 里 面 >) 。 


糟 灼 的 方式 一 一 “只 关注 构建 新 东西 ? 


已 实际 的 含义 是 “关注 构建 新 东西 ， 而 不 是 把 旧 的 产品 化 "。 真 有 人 
RAAF? 咽 ， 我 们 刚 开 始 的 时 候 就 种 犯 这样 的 错误 ， 我 相信 很 多 公司 
也 是 如 此 。 这 种 症状 跟 压 力 有 关 。 很 多 经 理 都 不 能 真正 理解 : 即使 所 有 
的 编程 活动 都 已 完成 ， 距 离 产 品 发 布 还 有 很 遥远 的 距离 。 人 至少 复 杂 系 统 
征 这 样 的。 所 以 经 理 《〈 或 者 产品 负责 人 ) 要 求 团 队 继续 增加 新 特性 ， 而 
大 家 手中 那些 “差不多 可 以 友 布 ”的 代码 就 越 来 越 多 ， 整 个 工作 的 速度 都 
会 因此 而 放 绥 。 























别 把 最 慢 的 一 环 逼 得 太 紧 


假设 验收 测试 是 你 那里 最 慢 的 一 环 。 测 试 人 员 稀 缺 ， 或 者 低劣 的 代 
码 质量 造成 了 过 长 的 验收 测试 周期 。 








假设 你 的 验收 测试 团队 每 星期 最 多 测试 三 个 特性 (不 ， 我 们 不 会 
用 “每 周 测试 的 特性 ?来 进行 度量 ， 我 只 是 在 这 个 例子 中 用 一 下 而 已 ) ， 
而 开发 人 员 每 星期 能 够 开发 6 个 特性 。 


经 理 或 者 产品 负责 人 《甚至 团队 ) 会 党 得 不 妨 安排 每 周 开发 6 个 特 
JE 





干 万 不 要 ! 你 最 终 一 定 会 认识 到 现实 的 残酷 ， 可 那 时 伤害 业已 造 
成 。 


实际 上 ， 应 该 安排 每 周 只 完成 3 个 特性 ， 多 余 的 时 间 用 来 攻克 测试 
的 瓶颈 。 


四 ”让 一 些 开 用 人 员 去 做 测试 人 员 的 工作 《〈 呢 ， 他 们 会 因此 而 爱 你 


上 ”实现 一 些 工 具 或 脚本 ， 用 来 简化 测试 工作 。 
m 增加 更 多 的 上 自动 化 测试 代码 。 
m 延长 Sprint 长 度 ， 把 验收 测试 放 到 sprint 里 面 来 。 


量 ” 把 一 些 sprint 定 义 为 “测试 sprint?， 其 中 整个 团队 都 作为 验收 测试 
团队 进行 工作 。 


e 雇佣 更 多 测试 人 员 《 即 使 这 会 意味 着 减少 开 友 人 员 ) 


这 些 解决 方案 我 们 全 都 试 过 《除了 最 后 一 点 ) 。 最 好 的 长 期 解决 方 
案 当 然 是 第 2 点 和 第 3 点 ， 即 更 好 的 工具 与 脚本 ， 还 有 训 试 上 自动化。 








回顾 可 以 帮助 我 们 更 好 地 识别 出 最 慢 的 一 坏 。 


回 到 现实 
也 许 我 的 话 会 让 你 认为 : 我 们 在 所 有 的 Scrum 团 队 中 都 有 测试 人 
员 ， 针 对 每 个 产品 都 有 大 规模 的 验收 测试 团队 ， 在 每 个 sprint 结 束 以 后 


都 会 进行 发 布 ， 等 等 ， 等 等 。 





其 实 ， 我 们 也 没有 做 到 。 

我 们 有 几 次 ”能 成 功 地 做 到 这 种 程度 ， 也 能 看 到 和 它 所 带 来 的 正面 影 
啊 。 但 我 们 的 质量 保证 过 程 想 要 得 到 认可 ， 还 有 很 长 的 路 要 走 ， 我 们 仍 
有 很 多 东西 要 学 。 





第 15 章 ”我 们 怎样 管理 多 个 Scrum 
团队 


四 ”创建 多 少 个 团队 

四 ”虚拟 团队 

mo 最 佳 的 团队 规模 

a em % sprint 

m ”为 什么 我 们 引入 “团队 领导 ”的 角色 
四 ”古人 否 使 用 特定 的 团队 

四” 我 们 怎样 在 团队 中 分 配 人 手 

m 是否 在 Sprint 之 间 重 新 组 织 团队 

四 ”古人 否 拆 分 产品 backlog 


m 多 团队 回顾 








在 多 个 Scrum 团 队 开发 同一 个 产品 的 状况 下 ， 很 多 事情 都 会 变 得 更 
加 复杂 、 理 手 。 这 个 问题 普 明 存在， 跟 Scrum 没 太 大 关系 。 更 多 开发 者 
三 更 多 复杂 情况 。 


我 们 也 (和 往常 一 样 ) 磁 到 过 这 种 情况 。 人 最 多 的 时 候 ， 曾 有 大 约 
40 个 人 开发 同一 个 产品 。 


这 里 有 下 面 两 个 核心 问题 。 
四 ”要 创建 多 少 个 团队 ? 


m ”如何 把 人 员 分 配 到 各 个 团队 中 ? 


创建 多 少 个 团队 


既然 管理 多 个 Scrum 团 队 这 么 困难 ， 那 我 们 干 啉 还 要 没事 儿 找 罪 受 
Ne? 为 啥 不 把 所 有 人 都 放 到 一 个 团队 里 面 去 呢 ? 








在 我 们 曾 有 过 的 团队 中 ， 单 个 Scrum 团 队 最 多 包括 11 个 人 。 大 家 可 
以 一 起 工作 ， 但 是 效果 不 好 。 每 天 的 Scrum 会 议 基 本 上 都 会 超过 15 分 
钟 。 每 个 人 都 不 太 清 楚 其 他 人 在 做 什么 ， 所 以 整个 状态 就 有 些 混 乱 。 
ScrumMaster 很 难保 证 每 个 人 都 在 问 同一 个 目标 努力 ， 也 不 太 能 找 得 到 
时 间 来 解决 发 现 的 所 有 问题 。 


有 人 可 能 会 建议 说 ， 把 大 团队 分 成 两 个 团队 。 但 这 样 做 情况 残 一 定 
会 好 转 么 ? 未必。 


如 果 这 个 团队 在 实施 Scrum 方 面 很 有 经 验 ， 也 习惯 这 种 做 法 ， 而 且 
能 够 以 符合 其 内 在 逻辑 的 方式 切 分 产品 ， 把 它 分 成 两 个 独立 的 部 分 ， 保 
证 各 目的 源 代码 不 会 重合 ， 那 把 团队 分 割 束 是 一 个 好 主意 。 不 然 我 还 是 
会 坚持 用 一 个 团队 ， 尽 管 大 团队 存在 种 种 缺陷 。 





我 的 经 验 是 ， 宁 可 团队 数量 少 ， 人 数 多 ， 也 比 弄 上 一 大 堆 总 在 互相 
干扰 的 小 团队 强 。 要 想 拆 分 小 团队 ， 必 须 确保 他 们 彼此 之 间 不 会 产生 互 
相干 扰 ! 


虚拟 团队 


在 “大 团队 > 和 * 多 团队 ”之 间 权衡 利 整 之 后 ， 你 做 出 了 自己 的 决策 
可 怎么 知道 这 种 决策 是 对 还 是 错 呢 ? 


如 果 注 意 观 察 、 仔 细 聆 听 ， 也 许 你 会 注意 到 “虚拟 团队 ”的 存在 。 


例 1 





你 选择 了 使 用 “大 团队 ”。 不 过 观察 一 下 sprint 中 的 交流 方式 ， 你 就 
能 发 现 事实 上 这 个 大 团队 目 动 分 成 了 两 个 子 团 队 。 





Scrum 团队 


虚拟 团队 。““ /虚拟 团队 
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例 2 





你 选择 了 使 用 三 个 小 团队 的 方式 。 不 过 观察 一 下 sprint 中 的 交流 方 
式 ， 你 就 会 发 现 团队 1 和 团队 2 一 直 在 交流 ， 而 团队 3 比较 孤立 。 


HEI GABA 
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那么 这 a 到底 意味 着 什么 呢 ? 是 你 的 团队 分 割 策略 有 问题 吗 ? OH 
果 类 似 虚 拟 团 队 一 直 这 样 保持 下 去 的 话 ， 那 就 表示 做 错 了 ; 如 果 只 是 暂 
时 的 话 ， 那 就 没 问题 。 


证 我 们 再 看 一 下 例 1。 如 果 这 两 个 虚拟 的 子 团 队 一 直 变 化 〈 也 就 是 
大 家 在 虚拟 团队 中 换 来 换 去 ) ， 那 把 他 们 放 到 一 个 团队 中 就 没有 问题 。 
如 果 二 者 的 构成 在 整个 sprint 中 保持 不 变 ， 在 下 个 sprint 中 可 能 就 得 考虑 
把 他 们 分 成 两 个 真正 的 Scrum 团 队 了 。 


现在 再 看 看 例 2。 如 果 团 队 1 和 团队 2 在 整个 sprint 中 一 直 聊 来 聊 去 
《把 团队 3 扔 在 一 边 ) ， 在 下 个 sprint 中 你 大 概 就 得 把 团队 1 和 2 合并 到 一 
块 。 如 果 在 sprint 的 前 半 阶 段 ， 团 队 1 和 团队 2 一 直 交 流 ， 然 后 在 后 半 阶 
段 ， 团 队 1 和 团队 3 又 相 谈 甚 欢 ， 那 合并 或 者 保持 原样 就 都 是 可 行 的 。 你 
可 以 在 sprint 回 顾 会 议 上 提出 这 个 问题 ， 让 团队 上 自己 决定 。 





在 Scrum 中 ， 团 队 分 割 确实 很 困难 。 不 要 想 得 太 多 ， 也 别 费 太 大 红 
儿 做 优化 。 先 做 实验 ， 观 察 虚拟 团队 ， 然 后 确保 在 回顾 会 议 上 有 足够 的 
时 间 来 讨论 这 种 问题 。 述 早 就 会 及 现 针对 你 所 在 环境 的 解决 方案 。 需 要 
重视 的 是 ， 必 须要 让 团队 对 所 处 环境 感到 和 舒适， 而且 不 会 章 着 役 此 干 
扰 。 





最 佳 的 团队 规模 


在 我 读 过 的 大 多 数 书 中 ，5 到 9 个 人 被 公认 为 是 “最 佳 的 ?团队 构成 人 
数 。 


从 到 目前 为 止 观察 到 的 情况 来 看 ， 我 同意 这 种 说 法 。 不 过 我 会 建议 
说 3 到 8 个 人 。 而 且 我 相信 ， 为 了 达到 这 种 团队 规模 ， 人 花 上 一 定 代价 还 是 
值得 的 。 





假设 你 有 一 个 10 人 的 Scrum 团 队 。 那 么 就 考虑 一 下 把 最 差 的 两 个 人 
Dh AE. E, REKA HLA? 


见 下 图 ， 假 设 你 有 两 个 不 同 的 产品 ， 每 个 产品 都 由 一 个 3 人 团队 负 
责 ， 进 度 都 很 慢 。 也 许 可 以 把 他 们 合并 成 有 6 个 人 的 团队 ， 同 时 负 贡 这 
两 个 产品 。 然 后 让 其 中 一 个 产品 负责 人 离开 这 里 《或 者 给 他 顾问 之 类 的 
角色 ) 。 


Product A + B 







产品 负责 和 产品 负责 人 
Scrum 团 F Scrum 团 队 Scrum 团 队 
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假设 你 的 团队 有 12 个 人 ， 因 为 代码 库 很 烂 ， 所 以 两 个 团队 不 可 能 独 
并 在 上 面 工作 。 那 就 应 该 认真 投入 时 间 、 精 力 修 复 代 码 库 (而 不 是 引入 








新 特性 ) ， 直 到 可 以 分 拆 团队 为 止 。 这 种 投资 很 快 就 可 以 得 到 回报 。 


是 否 同步 多 个 sprint 


假设 有 三 个 Scrum 团 队 开 发 同一 个 产品 。 他 们 的 sprint 应 该 同步 吗 ? 
在 同样 的 时 间 启 动 和 停止 ?或 者 应 该 交叉 覆盖 ? 


见 下 图 ， 我 们 一 开始 是 让 这 些 sprint 有 交叉 〈 考 虑 到 各 自 的 时 间 安 





团队 A Sprint A1 Sprint A2 | Sprint A3 

ABB | Sprint B1 | | Sprint B2 Sprint B3 

团队 C | Sprint C1 | Sprint C2 Sprint C3 
Ss Bh 8, SA _ 


听 上 去 挺 不 错 。 在 任何 一 个 给 定 的 时 间 点 上 ， 都 有 一 个 正在 进行 的 
Sprint 接近 结束 ， 而 新 的 Sprint 即将 开始 。 产 品 负责 人 的 工作 负担 会 随 着 
时 间 的 推移 逐步 挫 开 。 各 个 版 本 如 溪水 般 泪 泪 流 出 。 每 周 都 有 演示 。 老 
天 保佑 ! 


耶 ， 我 知道 你 想 说 什么 ， 但 大 家 从 前 
的 ! 


i 


戎 实 觉得 这 个 想法 挺 不 错 








我 们 一 开始 也 是 这 么 做 的 ， 直 到 有 一 天 我 有 机 会 跟 Ken 
Schwaber 〈 在 我 的 Scrum 认 证 期 间 ) 进行 了 交流 。 他 指出 这 种 做 法 很 有 
问题 ， 如 果 将 各 个 sprint 同 步 的 话 会 好 得 多 。 我 记 不 清 他 的 确切 理由 ， 
但 经 过 几 次 讨论 之 后 我 就 被 他 说 服 了 。 








从 那 以 后 我 们 束 采 用 了 下 图 所 示 的 解雇 方案 ， 也 从 没 觉得 有 什么 不 
对 劲 儿 的 。 我 也 没 机 会 了 解 那 种 交叉 的 方案 是 人 否 终 会 失败 ， 但 我 觉得 应 
该 如 此 。 同 步 进行 的 sprint 有 如 下 优点 。 


7 


加 ”可 以 利用 sprint 之 间 的 时 间 来 重新 组 织 团队 ! 如 果 各 个 Sprint 重 登 
的 话 ， 要 想 重新 组 织 团 队 ， 就 必须 打 断 至 少 一 个 团队 的 sprint 


进程 。 

e 所 有 团队 都 可 以 在 一 个 Sprint 中 辐 同 一 个 目标 努力 ， 他 们 可 以 有 
更 好 的 协作 。 

E 更 小 的 管理 压力 ， 即 更 少 的 sprint 计 划 会 议 、sprint 演 示 和 发 布 。 


Sprint 3 


| 


团队 A Sprint 1 Sprint 2 
团队 B Sprint 1 Sprint 2 Sprint 3 
团队 C Sprint 1 Sprint 2 | Sprint 3 


时 间 线 一 一 


为 什么 我 们 引入 “团队 领导 ”的 角色 


见 下 图 ， 假 设 我 们 有 三 个 团队 开发 同一 个 产品 。 


© 


Scrum 团 队 1 | | Scrum 团 队 2 1 { Scrum 团 队 3 
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那个 标记 为 "P” 的 家 伙 是 产品 负责 人 。 标 记 为 “$” 的 黑色 家 伙 是 











ScrumMaster。 其 他 的 束 是 一 直 哼 哼 嘿嘿 的 .……… Wee... 值得 尊敬 的 团队 
成 员 。 





在 这 个 群星 荟萃 的 团队 中 ， 谁 来 决定 哪些 人 属于 哪个 团队 ? 产品 负 
HA? 三 个 ScrumMasteI 集 体 决 定 ? 还 是 每 个 人 都 可 以 选择 自己 的 
A? 那 如 果 每 个 人 都 想 待 在 团队 1 里 面 怎么 办 〈( 因 为 第 一 个 ScrumMaster 
长 得 太 好 看 J)? 





如 果 后 来 发 现 最 多 只 能 有 两 个 团队 并 行 工 作 在 这 个 代码 库 上 ， 那 我 
们 束 得 把 这 三 个 6 人 团队 变 成 2 个 9 人 团队 。 那 当前 这 3 个 ScrumMaster 
中 ， 哪 一 个 会 失去 头衔 ? 


很 多 公司 都 有 这 种 敏感 问题 。 





有 人 可 能 会 觉得 让 产品 负责 人 来 做 人 员 分 配 是 个 好 主意 。 但 这 不 是 
产品 负责 人 职责 以 内 的 事情 ， 对 吧 ? 产品 负责 人 是 领域 专家 ， 他 可 以 指 
FANART, BAMAR ERLER. JRE 
如 果 他 是 “chicken” 的 话 ( 如 有 果 你 不 了 解 chicken 和 pig 的 隐喻 ， 可 以 google 
一 下 “chickens and pigs”) 。 








我 们 通过 引入 “团队 领导 ”的 角色 来 解决 了 这 个 问题 。 你 也 许 称 之 
为 “Scrum 中 的 ScrumMaster”， 或 者 “老大 ”， 也 或 者 “首席 
ScrumMaster" 等 。 他 不 用 领导 某 个 团队 ， 但 是 会 负责 路 团队 的 问题 ， 例 
如 谁 担任 哪个 团队 的 ScrumMaster， 大 家 如 何 分 组 等 等 。 








我 们 在 给 这 个 角色 取 名 字 的 时 候 费 了 好 大 劲 。 我 们 找到 了 很 多 名 
F, “团队 领导 ?已 经 算是 最 好 的 了 。 





这 种 方法 效果 很 好 ， 所 以 我 也 向 你 们 推荐 一 下 (怎么 给 这 个 角色 命 
名 就 无 所 谓 了 ) o 


我 们 怎样 在 团队 中 分 配 人 手 
有 多 个 团队 开发 同一 个 产品 时 ， 一 般 有 两 种 分 配 人 手 的 策略 。 





四 ”让 一 个 指定 的 人 来 做 分 配 ， 例 如 我 前 面 提 到 的 “团队 领导 ， 或 
产品 负责 人 ， 或 职能 经 理 〈《 如 果 他 的 参与 度 比 较 高 ， 就 可 以 做 
出 正确 的 决定 ) 。 





四 ”让 团队 自己 决定 。 


我 们 这 三 种 全 部 用 过 。 三 种 ?是 的 ， 宽 上 略 1， 寅 略 2， 还 有 二 者 的 组 


A 
我 们 发 现 二 者 组 合 以 后 的 效果 最 好 。 


在 sprint 计 划 会 议 之 前 ， 团 队 领 导 会 跟 产 品 负责 人 和 所 有 的 
ScrumMaster 一 起 开 团 队 分 配 会 议 。 我 们 共同 讨论 上 一 个 sprint， 决 定 是 
否 需 要 进行 重 分 配 。 也 许 会 合并 两 个 团队 ， 或 者 调换 某 个 人 。 我 们 就 一 
些 问 题 达 成 一 致 ， 并 写 到 团队 分 配 提案 中 ， 在 sprint 计 划 会 议 上 进行 讨 


论 。 





在 Sprint 计划 会 议 上 ， 我 们 首先 壳 历 产品 backlog 中 优先 级 最 高 的 条 
目 。 然 后 团队 领导 说 :“ 和 各位， 我们 建议 下 一 个 sprint 像 下 面 这 样 分 配 人 
手 。 ” 











团队 分 配 提 案 





团队 1 团队 2 团队 3 

- tom | - goofy - minnie 
- jerry - daffy - scrooge 
- donald - humpty - winnie 

- mickey - dumpty - [oo 








“你 们 看 ， 我 们 会 从 4 个 团队 变 成 3 个 。 每 个 团队 中 的 人 员 名 单 已 列 
出 来 了 。 你 们 可 以 凑 到 一 块 ， 目 己 丙 量 一 下 要 增 上 的 哪 块 地 方 。” 








《团队 领导 耐心 地 等 着 大 家 在 房间 里 转 您 ， 直 到 他 们 分 成 组， 各 
BAE RE To ) 


“目前 这 个 团队 分 配 只 是 初步 计划 ! 就 是 为 了 节省 点 大 家 的 时 间 。 
接 下 来 开会 的 时 候 ， 你 们 还 可 以 去 男 一 个 团队 ， 或 者 把 你 们 这 个 团队 一 
分 为 二 ， 或 者 跟 男 一 个 团队 合 二 为 一 ， 怎 么 都 行 。 做 选择 的 时 候 动 动脑 
子 ， 考 虑 一 下 产品 负责 人 定 下 来 的 优先 级 。” 





我 们 发 现 这 种 方式 效果 最 好 。 最 开始 使 用 一 些 集中 式 控制 ， 然 后 再 
用 分 散 式 优化 。 


是 否 使 用 特定 的 团队 
假设 你 们 的 技术 选 型 包括 下 面 三 种 主要 组 件 。 











客户 端 


IRIS tie 





DB 





再 比如 说 参与 开发 这 个 产品 的 有 15 个 人 之 多 ， 所 以 你 也 不 想 把 他 们 
都 放 在 一 个 Scrum 团 队 里 面 。 那 该 怎样 创建 团队 呢 ? 


方式 1: 特定 于 组 件 的 团队 


方式 之 一 是 创建 针对 特定 组 件 展 开工 作 的 团队 ， 例 如 “客户 端 
队 ”“ 服 务 器 团队 ”和 “DB 团队 ”。 


i Scrum 团 队 1 
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我 们 以 这 种 方式 开始 。 但 效果 不 太 好 ， 要 是 大 多 数 故 事 都 涉及 到 多 
个 组 件 就 更 糟 了 。 


比如 : 如 宁 有 一 个 名 为 “留言 板 ， 可 供用 户 在 上 面 给 彼此 留言 ?的 故 
事 。 这 个 特性 需要 更 新 客户 端的 用 户 界 面 ， 回 服务 器 中 添加 逻辑 ， 还 要 
增加 数据 库 中 的 表 。 
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这 就 意味 着 这 三 个 团队 一 一 客户 问 团 队 、 服 务 如 团队 和 DB 团队 需 
要 协作 来 完成 这 个 故事 。 情 况 不 妙 啊 ! 


方式 2: 跨 组 件 的 团队 


第 二 种 方式 是 创建 跨 组 件 的 团队 ， 也 就 是 说 团队 的 职 贡 不 会 个 束缚 
在 任何 特定 的 组 件 上 。 


etre ree reresesrseeers, 
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pm | 


DB 


如 末 大 多 数 故事 都 包括 多 个 组 件 ， 那 这 种 团队 划分 方式 的 效果 就 很 
服务 器 和 DB 三 部 分 的 完整 





好 。 每 个 团队 痢 可 以 目 己 实现 包括 客户 端 、 
故事 。 他 们 可 以 互相 独立 工作 ， 这 就 很 好 。 

我 们 在 实施 Scrum 的 时 候 ， 所 做 的 第 一 件 事情 就 是 打 乱 特定 于 组 件 
的 团队 方式 1) ， 创 建 跨 组 件 的 团队 方式 2〉。 它 减少 了 请 如 “我 们 
没 法 完成 这 个 条 目 ， 因 为 我 们 在 等 服务 需 那 帮 家 伙 完 成 他 们 的 工作 ”之 





类 的 情况 发 生 。 
不 过 ， 要 是 有 很 强烈 的 需求 ， 我 们 也 会 临时 创建 针对 特定 组 件 展 开 


工作 的 团队 。 


是 合 在 sprint 之 半 重 新 组 织 团 队 


一 般 来 讲 ， 由 于 各 目 优 先 级 最 高 的 故事 类 型 不 同 ， 不 同 的 sprint 之 
间 会 有 很 大 差别 ， 因 此 也 会 导致 各 个 sprint 理 想 的 团队 构成 也 有 所 不 
同 。 


实际 上 ， 几 平 在 每 个 sprint 中 我 们 都 会 发 现 自己 在 说 :“ 这 个 ”sprint 
确实 非 同 一 般 ， 原 因 在 于 ....….. ”一 段 时 间 以 后 ， 我 们 就 放弃 了 “ 普 
通 ”Sprint 的 观念 。 世 界 上 没有 普通 的 sprint， 束 像 没 有 “普通 ”的 家 许 
和 “普通 ”的 人 一 样 。 
在 Sprint 中 ， 组 建 一 个 只 负 贡 客户 端的 团队 ， 团 队 中 每 个 人 都 熟悉 
能 


客户 端 代码 ， 这 也 许 是 个 好 主意 。 到 了 下 个 sprint， 也 许 弄 两 个 跨 职 
团队 ， 把 负责 客户 端 代 码 的 人 拆 分 出 去 也 是 个 好 主意 。 





“团队 凝聚 力 ” 是 Scrum 的 核心 要 素 之 一 ， 如 果 一 个 团队 合作 工作 达 
多 个 sprint 之 信 ， 他 们 就 会 变 得 非常 紧密 ”。 他 们 会 学 会 如 何 达 成 团队 涌 
流 (group flow) 上 请 参见 
http://en.wikipedia.org/wiki/Flow_ (psychology) ” ， 译 者 注 ] ， 牛 产 力 
会 提升 至 难以 置信 的 地 步 。 不 过 要 达到 这 个 地 步 需要 花 上 一 定时 间 。 如 
果 不 断 变换 团队 组 成 ， 你 就 永远 无 法 得 到 强悍 的 团队 凝聚 力 。 





所 以 ， 如 果 你 确实 想 要 重新 组 织 团队 ， 请 先 考 虑 一 下 后 果 。 这 是 个 
长 期 变化 还 是 短期 变化 ? 如 果 是 短期 变化 ， 最 好 考虑 跳 过 这 一 步 。 如 末 
古 长 期 变化 ， 那 就 干 吧 。 





这 里 有 个 例外 : 第 一 次 在 大 型 团队 中 开始 实施 Scrum 的 时 候 ， 你 需 
要 就 团队 拆 分 进行 一 些 实验 ， 最 后 才能 找到 令 所 有 人 全 都 满意 的 做 法 。 


要 确保 所 有 人 部 能 够 理解 :在 最 开始 几 次 时 犯 些 错 误 是 可 以 接受 的 ， 只 
要 能 够 持续 改进 。 


FHA AI BA ie R 


我 很 认同 Scrum 书 中 所 说 的 话 一 一 在 Scrum 团 队 中 含有 兼职 成 员 一 
般 都 不 是 什么 好 主意 。 





假设 Joe 是 Scrum 团 队 中 的 兼职 成 员 。 在 让 他 进 团 队 之 前 ， 你 最 好 移 
认真 考虑 一 下 : 这 个 团队 确实 需要 Joe 么 ? 你 确定 Joe 不 能 全 职工 作 ? 他 
还 要 做 什么 其 他 事情 呢 ? 能 不 能 找 其 他 人 接 过 Joe 的 其 他 工作 ， 让 Joe 在 
那 份 工作 中 只 起 到 被 动 的 、 文 持 性 的 作用 ? Joe 能 不 能 从 下 一 个 sprint 起 
在 你 的 团队 中 全 职工 作 ， 同 时 把 他 的 其 他 工作 转交 给 其 他 人 ? 





有 时 就 是 没有 其 他 办 法 。 你 没有 Joe 不 行 ， 因 为 他 是 这 个 楼 里 唯一 
的 DBA， 但 是 其 他 团队 也 非常 需要 他 ， 所 以 他 永远 不 可 能 把 所 有 的 时 间 
都 分 配给 你 的 团队 ， 而 公司 也 不 能 雇用 其 他 DBA。 好 吧 。 这 种 情况 下 就 
可 以 让 他 兼职 工作 了 《这 恰恰 是 我 们 碰 到 的 情况 ) 。 但 你 要 确定 每 次 都 
进行 这 种 评估 。 

一 般 来 讲 ， 我 宁愿 要 三 个 全 职工 作 的 成 员 ， 也 不 愿意 要 8 个 只 能 做 
兼职 的 。 

如 果 有 一 个 人 需要 把 他 的 时 间 分 配给 多 个 团队 ， 就 像 上 面 提 到 的 
DBA 一 样 ， 那 最 好 让 他 有 一 个 主要 从 属 的 团队 。 找 出 最 需要 他 的 团队 ， 


把 它 当 作 他 的 “主队 ”。 如 果 没 有 其 他 人 把 他 拖 走 ， 那 他 就 得 参加 这 个 团 
队 的 每 日 scrum 会 议 、sprint 计 划 会 议 、 回 顾 等 等 。 


我 们 怎样 进行 Scrum-of-scrums 


Scrum-of-scrums 实 际 上 是 一 个 常规 会 议 ， 是 为 了 让 所 有 的 
ScrumMaster 聚 到 一 起 交流 。 

我 们 曾经 有 过 四 个 产品 ， 其 中 三 个 都 只 有 一 个 Scrum 团 队 ， 而 最 后 
一 个 产品 则 共有 25 人 ， 分 成 了 好 几 个 Scrum 团 队 ， 如 下 图 所 示 : 


Ta 
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这 意味 着 我 们 有 两 个 层次 的 Scrum-of-Scrums。 一 个 是 “产品 层次 ”的 
Scrum-of-Scrums， 包 括 Product  D 中 的 所 有 团队 ， 另 外 一 个 是 “团体 层 
次 ”的 Scrum-of-Scrums， 包 括 所 有 的 产品 。 





产品 层次 的 Scrum-of-Scrums 


这 个 会 议 非常 重要 。 我 们 一 周 开 一 次 ， 有 时 候 频 率 会 更 高 。 在 会 议 
上 我 们 会 讨论 集成 问题 ， 团 队 平 衡 问 题 ， 为 下 个 sprint 计 划 会 议 做 准 
备 ， 等 等 。 我 们 为 此 分 配 了 30 分 钟 时 间 ， 但 常常 超时 。 其 实 也 可 以 每 天 
进行 Scrum-of-Scrums， 但 我 们 一 直 没 有 时 间 尝 试 。 


我 们 的 Scrum-of-Scrums 议 程 安排 如 下 。 


1. 每 个 人 围 着 果子 坐 好 ， 摘 述 一 下 上 周 各 自 的 团队 都 完成 了 什么 
事情 ， 这 周 计 划 完 成 什么 事情 ， 遇 到 了 什么 障碍 。 





2. 其 他 需要 讨论 的 路 团队 的 问题 ， 例 如 集成 。 





Scrum-of-Scrums 的 议程 对 我 而 言 无 关 紧 要 ， 关 键 在 于 你 要 有 ” 定期 
召开 的 Scrum-of-Scrums 会 议 。 


体 层 次 的 Scrum-of-Scrums 


我 们 把 这 个 会 议 称 为 “脉动 ?我们 试 过 多 种 形式 ， 参 与 者 也 多 种 多 
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人 ) 会 议 。 时 长 15 分 钟 。 


什么 ? 15 分 钟 ? 全 体 参加 ? 每 一 个 产品 所 包括 的 全 部 团队 中 的 所 有 
人 都 会 参加 ? 这 能 行 么 ? 


的 ， 能 行 。 只 要 你 《或 是 其 他 主持 会 议 的 人 ) 严格 限定 会 议 的 时 


会 议 的 形式 如 下 。 
1. 主管 介绍 最 新 情况 。 例 如 即将 发 生 的 事件 信息 。 





2. 大 循环 。 每 个 产品 组 都 有 一 个 人 汇报 他 们 上 周 完成 的 工作 、 这 
周 计划 完成 的 工作 ， 以 及 碰 到 的 问题 。 其 他 人 也 会 作 报告 〈 配 
置 管理 领导 ，QA 领 寻 等 ) 。 





3. 其 他 人 都 可 以 自由 补充 任何 信息 ， 或 者 提问 问题 。 


这 是 一 个 发 布 概要 信息 的 论坛 ， 而 不 是 提供 讨论 或 者 反映 问题 的 场 
所 。 只 要 保证 这 一 点 ，15 分 钟 常常 就 足够 了 。 有 时 我 们 也 会 超时 ， 但 极 
少 会 占用 30 分 钟 以 上 的 时 间 。 如 末 出 现 了 热烈 的 讨论 ， 我 融会 打 断 它 ， 
请 感 兴趣 的 人 在 会 后 留 下 继续 讨论 。 


为 什么 我 们 要 进行 全 体 的 脉动 会 议 呢 ? 因为 我 们 发 现 团体 层次 上 的 
Scrum-of-Scrums 主 要 以 报告 形式 进行 ， 很 少 出 现 真 正 的 讨论 。 另 外 ， 在 
这 个 圈子 以 外 ， 有 许多 人 都 对 这 种 信息 非常 感 兴趣 。 基 本 上 大 家 都 想 知 
道 其 他 团队 在 做 些 什 么 。 所 以 我 们 想 ， 既 然 已 经 打 算 聚 到 一 起 ， 花 时 间 
来 告诉 彼此 每 个 团队 都 在 干什么 ， 那 为 什么 不 让 所 有 人 都 参加 呢 。 


交错 的 每 日 例会 


如 果 有 太 多 的 Scrum 团 队 参 与 单个 产品 的 开 及 ， 而 且 他 们 都 在 同一 
时 刻 进 行 每 日 例会 ， 那 你 就 过 到 问题 了 。 产 品 负责 人 《以 及 像 我 一 样 爱 
管 几 事 的 家 伙 )〉 因 此 每 天 只 能 参加 一 个 团队 的 每 日 例会 。 


所 以 我 们 要 求 团队 避免 在 同一 时 刻 进 行 每 日 例会 。 
房间 1 房间 2 





上 面 的 例子 中 ， 我 们 是 这 样 安排 的 : 每 日 例会 不 在 团队 房间 中 进 
行 ， 而 是 安排 在 不 同 的 房间 。 每 个 会 议 大 约 15 分 钟 ， 但 是 每 个 团队 在 房 
间 中 都 可 以 使 用 30 分 钟 的 时 间 ， 以 备 他 们 会 稍稍 超出 一 点 儿 时 间 。 





这 种 做 法 超级 有 效 ， 原 因 有 二 。 


1. 像 产 品 负责 人 和 我 这 样 的 人 可 以 在 一 个 早上 参加 所 有 的 例会 。 
想 清 楚 了 解 到 当前 的 sprint 进 展 状 况 ， 有 什么 严重 的 风险 ， 这 是 
最 好 的 方式 。 


2. 团队 成 员 可 以 参加 其 他 团队 的 例会 。 这 种 情况 不 常 发生， 不 过 
有 时 两 个 团队 会 在 相似 的 环境 下 工作 ， 所 以 会 有 几 个 人 参加 彼 
此 的 例会 来 保持 同步 。 
它 的 缺 把 是 减少 了 团队 的 自由 度 一 一 他 们 无 法 选择 他 们 上 自己 如 欢 的 
时 间 开 例会 。 不 过 这 一 直 没 成 为 我 们 的 问题 。 


救火 团队 


曾经 有 那么 一 次 ， 在 一 个 大 型 产品 的 开发 过 程 中 ， 我 们 实施 不 了 
Scrum， 因 为 团队 成 员 花 了 太 多 时 间 来 救火 一 一 拼命 忙 着 修复 早期 版 本 
中 的 bug。 这 是 个 恶性 循环 ， 影 响 很 坏 ， 他 们 花 了 太 多 时 间 救 火 ， 最 后 
根本 没有 时 间 进 行 前 颇 性 的 工作 来 防火 改进 设计 、 目 动 化 测试 、 创 建 
监控 工具 与 警报 工具 等 ) 


我 们 创建 了 一 个 专门 的 救火 团队 ， 一 个 专门 的 Scrum 团 队 ， 从 而 解 
决 了 这 个 问题 。 


这 个 Scrum 团 队 的 工作 是 〈 带 着 产品 负责 人 的 祝愿 ) 稳定 系统 ， 有 


效 防 火 。 
救火 团队 《实际 上 我 们 管 他 们 叫 “ 文 持 团 队 ”) 有 两 项 工作 。 
1. 救火 。 


2. 保护 Scrum 团 队 远离 各 种 和 干扰， 包括 挡 开 那些 不 知 从 何 而 来 的 、 
增加 临时 特性 的 要 求 。 





救火 团队 被 安排 在 离 门 最 近 的 地 方 ，Scrum 团 队 坐 在 房间 的 最 里 
面 。 所 以 救火 团队 可 以 真正 地 从 物理 上 保护 Scrum 团 队 ， 使 他 们 不 会 受 
到 急切 的 销售 人 员 或 者 怒气 冲冲 的 客户 的 干扰 。 


两 个 团队 中 都 有 品级 工程 是， 这样 一 个 团队 就 不 会 过 于 依赖 男 一 个 
团队 的 核心 人 员 。 


这 实际 上 也 是 对 解决 Scrum 自 行 局 动 问题 的 一 种 笃 试 。 如 果 团 队 的 
工作 计划 总 是 只 能 安排 一 天 之 内 的 工作 ， 那 我 们 怎么 开始 做 Scrum 呢 ? 
就 像 上 面 所 讲述 的 那样 ， 我 们 的 策略 是 分 割 团 队 。 








这 种 方式 效果 很 好 。 因 为 Scrum 团 队 有 了 空间 努力 工作 ， 所 以 他 们 
最 后 能 够 稳定 系统 。 同 时 救火 队员 也 完全 放弃 了 预先 计划 的 想法 ， 他 们 
完全 是 针对 外 部 反应 展开 工作 ， 只 管 修 复 即 将 出 现 的 下 一 个 问题 。 





当然 ，Scrum 团 队 也 不 是 完全 远离 干扰 。 救 火 团 队 和 常常 需要 Scrum 
团队 中 核心 人 员 的 帮助 ， 在 最 糟糕 的 状况 下 ， 甚 至 会 需要 整个 团队 。 








但 无 论 如 何 ， 经 过 几 个 月 以 后 ， 这 个 系统 达到 了 足够 稳定 的 状态 ， 
然后 我 们 解散 了 救火 团队 ， 男 外 创建 了 一 个 新 的 Scrum 团 队 。 救 火 队员 
们 很 高 兴 地 把 已 经 磨损 的 头 番 放 到 一 边 ， 加 入 到 Scrum 团 队 中 。 


古人 否 拆 分 产品 backlog 


假设 你 有 一 个 产品 和 两 个 Scrum 团 队 ， 那 应 该 有 几 个 产品 backlog 
WE? 多 少 个 产品 负责 人 ? 我 们 曾经 为 此 评估 过 三 个 模型 。 选 择 不 同 ， 
sprint 计 划 会 议 的 形式 就 会 有 很 大 差异 。 





策略 1: 一 个 产品 负责 人 ， 一 个 backlog 


这 就 是 “只 能 有 一 个 ”的 模型 ， 也 是 我 们 最 推 革 的 模型 。 





这 种 模型 的 优点 是 : 你 可 以 让 团队 根据 产品 负 贡 人 当前 的 优先 级 来 
目 行 管理 。 产 品 负责 人 关注 他 所 需要 的 东西  ， 团 队 诀 定 怎么 分 割 工 


作 。 


说 得 更 具体 一 些 ， 我 们 来 看 看 这 个 团队 sprint 计 划 会 议 的 举行 方 
式 : Sprint 计划 会 议 在 一 个 外 部 的 会 议 中 心 举 行 。 


在 会 议 开始 之 前 ， 产 品 负 员 人 指定 一 面 增 壁 用 做 “产品 backlog 增 ”， 
把 故事 贴 在 上 面 ( 以 索引 卡 的 形式 ) ， 按 相对 优先 级 的 顺序 排序 。 他 不 
断 往 上 面 贴 故 事 ， 直 到 贴 满 为 止 。 通 常 他 贴 上 去 的 东西 都 要 比 一 个 
sprint 中 所 能 完成 的 条 目 多 。 





每 个 Scrum 团 队 各 上 自选 择 增 上 的 一 块 空白 区 域 ， 贴 上 自己 团队 的 名 
字 。 那 就 是 他 们 的 “团队 墙 *。 然 后 他 们 从 最 高 优先 级 的 故事 开始 ， 从 产 
癌 backlog 增 上 把 故事 逐一 挪 到 他 们 自己 的 团队 墙 上 。 





这 个 过 程 可 以 用 下 图 来 描述 ， 图 中 的 第 头 表 示 故 事 卡 从 产品 backlog 
省 移动 到 团队 墙 的 过 程 。 
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企 会 议 进行 中 ， 产 品 负责 人 与 团队 会 针对 索引 卡 进 行 讨 论 、 把 它们 
在 团队 之 间 移 动 、 上 下 挪动 以 调整 优先 级 、 把 它们 拆 分 成 更 小 的 条 目 ， 
等 等 。 过 上 大 概 一 小 时 左右 ， 每 个 团队 就 会 在 自己 的 团队 场 上 形成 一 个 
sprint ”backlog 的 初步 候选 版 本 。 然 后 团队 便 会 独立 工作 ， 进 行 时 间 估 
算 ， 把 故事 拆 分 成 任务 。 








整个 过 程 显 得 特别 嘲 杂 混乱 ， 令 人 筋疲力尽 ， 但 同样 也 效果 很 好 ， 
很 有 趣 ， 也 是 个 社会 交往 的 过 程 。 到 结束 时 ， 所 有 团队 通常 都 会 得 到 足 
够 的 信息 来 局 动 他 们 的 sprint。 


策略 2: 一 个 产品 负责 人 ， 多 个 backlog 





在 这 种 策略 中 ， 产 品 负 责 人 会 维护 多 个 ”产品 backlog， 每 个 团队 对 
应 一 个 。 我 们 没有 真正 试 过 这 种 方式 ， 不 过 差点 儿 就 这 么 做 了 。 这 有 是 我 
们 的 后 备 方案 ， 以 防 第 一 种 策略 失败 。 








它 的 劣势 在 于 ， 产 品 负责 人 要 把 故事 分 配给 团队 ， 而 这 项 工作 区 给 
团队 目 己 处 理会 更 好 。 
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TRUS: 多 个 产品 负 贡 人 ， 每 人 一 个 产品 backlog 


它 跟 第 二 个 集 略 有 点 像 ， 每 个 团队 都 有 一 个 产品 backlog， 但 每 个 团 
队 也 都 有 一 个 产品 负责 人 ! 


我 们 没有 用 过 这 种 方式 ， 也 许 永远 也 不 会 用 。 


如 宁 两 个 产品 backlog 都 对 应 同一 个 代码 库 ， 那 两 个 产品 负责 人 可 能 
会 发 生 严重 的 利害 冲突 。 


| Sy 3 wA 
产 品 yma pe 品 J AA 
| 负责 人 负责 人 


Backlog Backlog ! 


38661668 
1868 888 


如 果 两 个 产品 backlog 所 对 应 代码 库 不 同 ， 那 这 样 做 ， 就 跟 把 整个 产 
品 分 成 不 同 的 子 产 品 然后 独立 运作 毫 无 二 致 。 也 就 表示 着 我 们 回 到 了 每 
个 团队 一 个 产品 的 情况 ， 这 样 处 理 起 来 既 愉 快 义 轻松 。 


代码 分 文 


有 多 个 团队 在 同一 个 代码 库 基 础 上 工作 ， 我 们 就 势必 会 磁 到 
SCM 〈 软 件 配 置 管理 ) 系统 中 的 代码 分 文 问 题 。 现 在 已 经 有 很 多 关于 处 
理 多 人 协同 工作 问题 的 书 和 论文 了 ; 所 以 我 这 里 也 就 不 再 谈 什 么 细 市 。 
我 也 没有 什么 新 东西 或 者 单 命 性 的 观点 ， 下 面 会 总 结 一 下 我 们 团队 到 目 
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前 为 止 学 到 的 最 重要 的 一 些 经 验 。 


E EA CET) 的 状态 要 严格 保持 一 致 : 最 起 码 所 有 的 东西 


都 要 能 够 进行 编译 ， 所 有 的 单元 测试 都 可 以 通过 。 每 时 每 刻 
都 能 创建 一 个 可 以 工作 的 发 布 版 本 。 如 果 可 以 做 到 持续 构建 系 
统 在 每 晚 进行 构建 ， 并 把 结果 目 动 部 团 到 测试 环境 中 残 更 好 
Ts 


四 ”给 每 个 版 本 打上 标记 (tag) 。 无 论 什么 时 候 ， 只 要 是 为 验收 测 





试 进 行 发 布 ， 或 是 发 布 到 产品 环境 ， 在 主线 中 束 应 该 进行 版 本 
标记 ， 用 来 精确 标识 所 发 布 的 内 容 。 这 便 意味 看 在 将 来 的 任 一 
时 刻 ， 你 都 可 以 回 退 到 某 个 历史 版 本 中 ， 创 建 一 个 维护 分 文 。 














只 在 必需 的 时 候 创 建 分 文 。 这 里 有 一 条 很 好 的 规则 : 如 果 你 无 
法 在 不 违反 现 有 代码 基线 策略 的 情况 下 使 用 该 代码 基线 ， 那 么 
只 有 ”在 这 种 情况 下 ， 才 能 创建 新 的 代码 基线 。 如 果 挽 不 准 是 
什么 情况 ， 那 就 不 要 创建 分 文 。 为 什么 ”因为 每 个 活动 分 支 都 
会 增加 复杂 性 ， 提 高 管理 成 本 。 








将 分 文 主要 用 于 分 离 不 同 的 生命 周期 。 无 论 你 是 否决 定 让 每 个 
团队 在 他 们 上 自己 的 代码 基线 上 进行 编码 ， 如 采 你 打算 在 同一 个 
代码 基线 上 将 短期 的 修复 版 与 长 时 间 的 变化 进行 合并 ， 到 时 候 
就 会 发 现 : 要 发 布 这 个 短期 的 修复 版 绝 非 易 事 ! 





经 党 同步。 如 果 你 在 分 文 上 工作 ， 那 么 只 要 有 了 一 些 代码 可 以 
构建 ， 就 应 该 与 主线 进行 同步 。 在 每 天 的 编码 工作 开始 之 前 ， 
都 把 代码 从 主线 同步 到 分 支 上 ， 这 样 你 的 分 支 就 可 以 与 其 他 团 
队 所 做 出 的 变化 保持 更 新 。 如 果 会 产生 让 你 觉得 生 不 如 死 的 合 








并 情况 ， 那 也 只 能 接受 这 种 现实 ， 因 为 等 下 去 的 结果 只 会 更 


多 团队 回顾 
如 果 有 多 个 团队 开发 同一 个 产品 ， 我 们 怎样 做 sprint 回 顾 呢 ? 


在 Sprint 演示 结束 以 后 ， 大 家 豆 掌 、 相 拥 ， 然 后 每 个 团队 立刻 回 到 
自己 的 房间 ， 或 者 办 公 室 之 外 的 某 个 舒适 场所 。 他 们 各 目的 回顾 方式 与 
我 在 第 10 章 “我 们 怎样 做 Sprint 回顾 ”中 描述 的 情况 并 没什么 不 同 。 


在 Sprint 计划 会 议 上 《因为 我 们 在 同一 个 产品 中 使 用 的 是 同步 的 
sprint， 上 所 以 所 有 团队 均 会 参加 ) ， 第 一 件 事 情 就 是 让 每 个 团队 找 出 一 
个 发 言 人 ， 站 起 来 总 结 他 们 回顾 中 得 出 的 关键 点 。 每 个 团队 都 有 5 分 钟 
的 时 间 。 然 后 我 们 会 进行 大 约 10 到 20 分 钟 的 开放 讨论 。 之 后 稍 作 休整 ， 
开始 真正 的 Sprint 计划 。 











我 们 没有 试 过 其 他 方式 ， 这 样 已 经 足够 了 。 不 过 最 大 的 缺点 就 是 在 
回顾 之 后 、 计 划 会 议 之 前 没有 休整 时 间 (参见 第 11 章 “sprint 之 间 的 休整 
时 刻 ”) 。 


对 于 单个 团队 的 产品 ， 我 们 就 不 会 在 sprint 计 划 会 议 上 对 回顾 进行 
总 结 了 。 因 为 这 没有 必要 ， 每 个 人 都 参与 了 真正 的 回顾 会 议 。 


第 16 章 ”我们 怎样 官 理 分 布 式 团 队 


2 BH 


四 ”在 家 工作 的 团队 成 员 


如 果 团 队 成 员 处 于 不 同 地 理 位 置 该 怎么 办 ? Scrum 和 XP 的 大 部 
分 “魔力 ”要 想 发 挥 作 用 ， 团 队 的 成 员 们 最 好 身 处 同 地 紧密 协作 、 可 以 结 
对 编程 ， 而 且 能 做 到 每 日 面对面 交流 。 





我 们 有 一 些 分 散 的 团队 ， 也 有 些 团 队 成 员 时 时 在 家 工作 。 


我 们 的 策略 很 简单 : 就 是 想 尽 办 法 来 把 物理 位 置 上 分 散 的 团队 成 员 
之 间 的 沟通 带 客 增 至 最 大 。 我 不 只 是 说 每 秒 传递 多 少 兆 字 市 (当然 这 也 
很 重要 ) ， 还 包括 含义 更 广 的 沟通 带宽 。 


四 能够 一 起 结对 编程 。 

四 能够 在 每 日 例会 上 面对面 交流 。 
m ”在 任何 时 候 都 能 够 面对面 讨论 。 
四 ”可 以 真正 地 磁 面 与 交往 。 

四 ”整个 团队 可 以 主动 举行 会 议 。 


加 ”团队 对 sprint backlog、sprint 燃 尽 图 、 产 品 backlog 和 其 他 信息 传 
递 设施 有 相同 的 理解 。 





我 们 还 采取 过 下 面 这 些 措施 (或 者 是 正在 试 着 实施 ， 到 现在 还 没有 
全 都 用 到 过 ) 。 


e 每 一 合 工作 站 前 面 都 配备 网 络 摄像 头 和 耳麦。 


四 ”可 以 远程 通话 的 会 议 室 ， 带 有 网 络 摄像 头 、 会 议 用 麦 区 风 、 随 
时 可 用 的 计算 机 和 呆 面 共 至 软件 等 等 。 


m “还 程 窗口 ?。 每 个 地 方 都 有 大 屏幕 ， 显 示 其 他 地 点 的 固定 男 
面 。 就 像 两 个 公寓 之 间 的 虚拟 窗口 一 样 。 你 可 以 看 到 谁 坐 在 座 
位 前 ， 谁 在 跟 谁 说 话 。 这 可 以 增强 “我 们 是 在 一 起 工作 ”的 感 


i» 
Who 


加 ”交换 程序 。 来 自 每 一 个 地 方 的 人 按照 某 个 规律 交叉 访问 。 





通过 类 似 技 术 以 及 更 多 手段 ， 我 们 可 以 慢 慢 掌握 到 ， 如 何在 地 理 分 
布 的 团队 之 间 开 展 sprint 计 划 会 议 、 演 示 、 回 顾 和 每 日 scrum 会 议 等 等 。 


和 其 他 规律 一 样 ， 这 也 是 通过 不 断 的 实验 总 结 出 来 的 。 观 察 
=> ii HO = 观 We => iii bis = 观 察 => jj] => WR => 调 整 => 检 查 =a 


| 


离 岸 
我 们 也 有 一 些 离 岸 团队 ， 并 且 尝 试 过 如 何 用 Scrum 来 提高 协作 效 


离 尾 的 方式 主要 分 为 两 种 ， 分 散 的 团队 和 分 散 的 团队 成 员 。 


分 散 的 团队 


一- 一 一 一 一 一 一 一 一 一 一 一 人 


OTT 


`. ocecccccsseerosot" 


分 散 的 团队 成 员 
a B 国 
A o> 6,8 | ee 
ns 


和 


第 一 种 方式 是 被 迫 下 的 选择 。 不 过 我 们 还 是 先 以 第 二 种 方式 开始 离 
EFR. RAW F. 


1. 我 们 希望 团队 成 员 可 以 对 彼此 有 很 好 的 了 解 。 
2. 我 们 希望 在 两 地 之 间 能 够 有 展 好 的 沟通 基础 ， 也 想 让 团队 有 强 


烈 的 愿望 来 把 基础 打 好 。 


3. 在 刚 开始 的 时 候 ， 离 岸 团 队 比 较 小 ， 没 法 上 利己 组 成 一 个 有 效 的 
Scrum 团 队 。 








4， 在 独立 离 岸 团队 可 以 正常 运作 之 前 ， 我 们 要 有 一 段 紧张 忙碌 的 
言 息 共 享 时 期 。 


Buty FN 





从 长 期 来 看 ， 我 们 也 许 会 顺利 过 渡 到 “分 散 的 团队 ”这 种 方式 上 去 。 


在 家 工作 的 团队 成 员 


在 家 工作 有 时 候 会 效果 很 好 。 有 时 ， 你 在 办 公 室 里 一 星期 也 于 不 完 
的 工作 ， 在 家 里 一 天 就 搞定 了 。 只 要 你 没有 和 孩子 的 话 : o) 





不 过 ， 团 队 应 该 处 在 相同 的 物理 位 置 是 Scrum 的 基本 原则 之 一 。 那 
我 们 是 怎么 做 的 呢 ? 


通常 我 们 让 团队 目 己 决定 在 家 工作 的 时 间 和 频率 。 有 些 团队 成 员 因 
为 家 和 办 公 室 的 距离 太 远 ， 所 以 常 音 在 家 工作 。 不 过 我 们 还 是 或 励 团 队 
在 “大 多 数 ? 时 间 尽 量 聚 在 一 起 。 


在 家 工作 时 ， 他 们 会 通过 Skype 语 音 通话 来 参加 每 日 Scrum 会 议 。 他 
们 整 天 都 保持 在 线 ， 可 以 进行 实时 通信 。 虽 然 比 起 在 同一 个 房间 里 还 是 
有 差距 ， 但 这 也 不 错 了 。 





我 们 曾经 试 过 把 星期 三 作为 聚焦 日 。 这 表示 “如 果 你 想 在 家 工作 ， 
这 没 问 题 ， 不 过 只 能 在 星期 三 ， 而 且 要 得 到 团队 许可 。” 这 种 做 法 很 有 
效 。 通 常 大 多 数 人 部 会 在 星期 三 待 在 家 里 ， 完 成 大 量 工 作 ， 同 时 还 能 协 
作 得 很 好 。 因 为 这 只 有 一 天 ， 所 以 团队 成 员 不 会 脱离 彼此 同步 的 状态 太 
和 久 。 不 过 由 于 茶 些 原因 ， 这 种 做 法 从 来 都 没有 在 其 他 团队 中 流行 起 来 。 








总 的 来 资 ， 团 队 成 员 在 家 工作 ， 对 我 们 而 言 基本 上 没有 问题 。 


第 17 音 。” ScrumMaster 检 徊 列表 


m Sprint 开始 阶段 
上 ”每 一 天 


四 ”在 Sprint 结束 时 





在 最 后 这 一 章 ， 我 会 展示 一 下 我 们 的 ScrumMaster“ 检 查 列 表 ”。 它 
列 出 了 我 们 的 ScrumMaster 日 党 执行 的 常用 管理 事务 。 这 些 都 很 容易 被 
人 们 起 记 。 有 些 很 显而易见 的 事情 我 们 就 略 过 不 提 了 ， 如 “消除 团队 的 


障碍 ”。 





Sprint 开始 阶 段 
四 Sprint 计划 会 议 之 后 ， 创 建 sprint 信 息 页 面 。 
O “在 wiki 上 创建 从 dashboard 指 向 所 创建 页 面 的 链接 。 


O 把 页 面 打 印 出 来 ， 贴 在 通过 你 们 团队 工作 区 域 之 外 的 墙 
上 ， 让 经 过 的 人 都 可 以 看 到 。 


四 ”给 每 个 人 发 邮件 ， 声 明 新 的 sprint 已 经 启动 。 邮 件 中 要 包括 sprint 
目标 和 指向 sprint 信 息 页 面 的 链接 。 


四 ”更 渐 Sprint 数 据 文档 。 加 入 估算 生产 率 、 团 队 大 小 和 sprint 长 度 


FY 
等 。 


一 大 


确保 每 日 Scrum 会 议 可 以 按时 开始 和 结 
为 了 保证 sprint 可 以 如 期 完成 ， 需 要 适当 地 增删 故事 。 





O 确保 产品 负责 人 了 解 这 些 变 化 ，。 
确保 团队 可 以 及 时 得 知 sprint backlog 和 燃 尽 图 的 最 新 状况 。 


确保 存在 的 问题 和 障碍 都 能 被 解决 ， 并 报告 给 产品 负责 人 以 及 
(或 者 ) 开发 主管 。 


在 Sprint 结束 时 
四 ”进行 开放 式 的 Sprint 演示 。 
四 ”在 演示 开始 前 一 两 天 ， 就 要 通知 到 每 个 人 。 


em 与 整个 团队 以 及 产品 负责 人 一 起 开 sprint 回 顾 会 议 。 开 发 主管 也 
应 该 受 邀 参加 ， 他 可 以 把 你 们 的 经 验 教 训 大 范围 传播 开 来 。 


m 更 新 Sprint 数据 文档 。 加 入 实际 生产 率 和 回顾 会 议 中 总 结 出 的 天 
键 点 。 


第 18 章 ”结语 


四 推荐 阅读 


We! 真 没 想 过 这 本 书 会 写 到 这 么 长 。 











无 论 你 是 初 涉 Scrum， 还 是 已 饱 经 风霜， 和 希望 它 都 能 带 给 你 一 些 有 


用 的 想法 。 


因为 Scrum 必 须 针 对 每 一 种 不 同 的 环境 来 进行 具体 实施 ， 所 以 很 难 
站 在 通用 的 角度 上 讨论 何谓 最 佳 实践 。 不 过 无 论 如 何 ， 我 都 布 望 能 够 听 
到 你 的 反馈 。 告 诉 我 你 的 做 法 和 我 有 什么 区 别 。 告 诉 我 如 何 改进 ! 


你 可 以 通过 henrik.kniberg@crisp.se KK AK. KANwWAw HK 


/Escrumdevelopment@yahoogroups.com 。 


如 果 你 喜欢 这 本 书 ， 也 许 会 对 我 的 博客 感 兴 趣 。 我 也 会 在 上 面 写 一 
些 有 关 Java 和 敏捷 开发 的 话题 : 


http://blog.crisp.se/henrikkniberg/ 





推荐 阅读 
我 的 众多 灵感 与 思想 都 来 自 于 下 面 这 些 书 。 强 烈 推荐 ! 
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有 关 Henrik kniberg 





Henrik Kniberg (henrik.kniberg@crisp.se ) 是 一 名 咨询 师 ， 在 斯 德 
哥 尔 摩 的 Crisp 公 司 Cwww.crisp.se ) 工作 。 他 的 专长 是 Java 和 敏捷 软件 
TR 





目 从 第 一 本 有 关 XP 的 书籍 和 敏捷 宣言 问世 以 来 ，Henrik 就 开始 拥抱 
敏捷 原则 ， 并 尝试 在 不 同 的 组 织 中 进行 有 效应 用 。 在 1998 年 至 2003 年 
间 ， 他 作为 Goyada 的 合作 创始 人 和 CTO， 构 建 并 管理 一 个 技术 平台 和 30 
人 的 开发 团队 ， 充 分 试验 了 测试 驱动 开发 及 其 他 敏捷 实践 。 


在 2005 年 末 ，Henrik 签 约 了 瑞典 的 一 家 游戏 行业 公司 ， 作 为 该 公司 
的 开发 部 门 主管 。 当 时 该 公司 形势 危 如 昧 卵 ， 组 织 管理 及 技术 方面 的 问 


题 极 其 严峻 。 通 过 使 用 Scrum 和 XP，Henrik 将 敏捷 和 精益 原则 贯彻 到 公 
司 的 各 个 方面 ， 帮 助 公司 走出 了 困境 。 





2006 年 11 月 的 一 个 星期 五 ，Henrik 因 为 发 烧 生 病 ， 在 家 卧床 。 他 决 
定 记 录 下 在 过 去 的 几 年 中 所 学 到 的 知识 。 不 过 一 经 启动 ， 他 就 再 难 搁 
笔 ， 经 过 三 天 的 疯狂 之 后 ， 这 份 最 原始 的 记录 已 经 扩张 成 一 份 80 页 的 长 
文 ， 名 为 “硝烟 中 的 Seum 和 XP”， 最 后 则 形成 了 这 本 小 书 。 





Henrik 走 了 一 条 全 面 发 展 的 道路 ， 他 在 各 种 角色 之 间 怡 然 自 乐 : 经 
理 、 开 发 人 员 、ScrumMaster、 教 师 与 教练 。 他 一 直 致 力 于 帮助 公司 构 
建 优秀 软件 与 优秀 团队 ， 充 当 各 种 必需 的 角色 。 


Henrik 在 东京 长 大 ， 目 前 与 他 的 妻子 Sophia 和 两 个 孩子 生活 在 斯 德 
哥 尔 摩 。 他 在 空 采 时 间 还 是 一 名 活跃 的 音乐 家 ， 跟 当地 乐队 一 起 创作 乐 
曲 ， 玩 贝 司 和 键盘 。 


这 个 网 站 上 有 他 的 更 多 信息 : 


http://www.crisp.se/henrik.kniberg 


